
    * { box-sizing: border-box; }
    :root {
      --redo-icon-color: #eb5202;
      /* Keep page-editor actions left of the top-right account menu + dropdown */
      --admin-toolbar-account-reserve: 220px;
    }
    body { margin: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif; background: #f0f0f0; color: #303030; min-height: 100vh; }
    .hidden { display: none !important; }

    /* Until authenticated, keep admin shell copy out of sight (view-source still contains markup). */
    html.admin-auth-guest #app-shell .grid-view-intro-desc {
      visibility: hidden;
      user-select: none;
    }

    #login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
    .login-card { background: #fff; border: 1px solid #d1d1d1; border-radius: 4px; padding: 32px; width: 100%; max-width: 400px; box-shadow: 0 1px 3px rgba(0,0,0,.08); }
    .login-card__heading { margin: 0 0 20px; font-size: 1.25rem; font-weight: 600; color: #333; }
    .login-card input, .login-card button { padding: 10px 12px; margin: 6px 0; width: 100%; border: 1px solid #adadad; border-radius: 2px; }
    .login-card button { background: #eb5202; color: #fff; border-color: #eb5202; font-weight: 600; cursor: pointer; }
    .login-card button:hover { background: #d24b02; }
    .login-card button:disabled { opacity: 0.65; cursor: wait; }
    .error { color: #b30000; margin-top: 10px; font-size: 0.875rem; }
    .success { color: #006400; margin-top: 10px; font-size: 0.875rem; }
    .login-feedback {
      margin-top: 8px; margin-bottom: 4px; min-height: 1.35em; line-height: 1.45;
      font-size: 0.875rem; color: #444;
    }
    .login-feedback.error {
      color: #a40000; font-weight: 600; padding: 10px 12px; background: #fff5f5;
      border: 1px solid #f0c0c0; border-radius: 4px;
    }

    #app-shell { display: flex; min-height: 100vh; }
    #sidebar {
      --sidebar-width: 230px;
      width: var(--sidebar-width); flex-shrink: 0; background: #353d4a; color: #e3e3e3;
      display: flex; flex-direction: column; border-right: 1px solid #2a3138;
    }
    #sidebar.menu-icons-only { --sidebar-width: 72px; }
    /* Icons-only: hide labels on first-level sidebar entries only (not flyout panel items). */
    #sidebar.menu-icons-only #admin-main-menu > .menu-item .menu-item-label,
    #sidebar.menu-icons-only #admin-main-menu > .flyout-wrap > .menu-item .menu-item-label,
    #sidebar.menu-icons-only #admin-main-menu > .flyout-wrap > .menu-item .chevron,
    #sidebar.menu-icons-only #admin-main-menu > .menu-display-toggle-wrap .menu-item-label,
    #sidebar.menu-icons-only #menu-wellness-trigger .menu-item-label,
    #sidebar.menu-icons-only #menu-wellness-trigger .chevron,
    #sidebar.menu-icons-only #menu-fitness-trigger .menu-item-label,
    #sidebar.menu-icons-only #menu-fitness-trigger .chevron {
      display: none !important;
    }
    #sidebar.menu-icons-only #admin-main-menu > .menu-item,
    #sidebar.menu-icons-only #admin-main-menu > .flyout-wrap > .menu-item,
    #sidebar.menu-icons-only #admin-main-menu > .menu-display-toggle-wrap > .menu-item {
      justify-content: center;
      padding-left: 12px;
      padding-right: 12px;
      gap: 0;
    }
    #sidebar.menu-icons-only #menu-wellness-trigger {
      justify-content: center;
      padding-left: 12px;
      padding-right: 12px;
      gap: 0;
    }
    #sidebar.menu-icons-only #menu-fitness-trigger.menu-item-sub {
      justify-content: flex-start;
      padding-left: 20px;
      padding-right: 12px;
      gap: 0;
    }
    #sidebar.menu-icons-only .brand {
      padding-left: 10px;
      padding-right: 10px;
      text-align: center;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .menu-display-toggle-wrap {
      margin-top: 6px;
      padding-top: 6px;
      border-top: 1px solid #2a3138;
    }
    .menu-display-toggle[aria-pressed="true"] {
      background: rgba(235, 82, 2, 0.12);
      border-left-color: rgba(235, 82, 2, 0.55);
    }
    #sidebar .brand { padding: 18px 16px; font-weight: 700; font-size: 1.05rem; letter-spacing: .02em; border-bottom: 1px solid #2a3138; color: #fff; }
    #sidebar .menu { flex: 1; padding: 8px 0; overflow-x: visible; overflow-y: auto; min-height: 0; }
    #sidebar { overflow: visible; }
    .menu-item {
      display: flex; align-items: center; gap: 12px; width: 100%; padding: 12px 16px;
      border: none; background: transparent; color: inherit; font-size: 0.9375rem; text-align: left; cursor: pointer;
      border-left: 4px solid transparent; text-decoration: none; font-family: inherit;
      min-width: 0;
    }
    .menu-item > span {
      min-width: 0;
      flex: 1 1 auto;
    }
    .menu-item:hover { background: rgba(255,255,255,.06); color: #fff; }
    .menu-item.active { background: rgba(255,255,255,.08); color: #fff; border-left-color: #eb5202; }
    .menu-item svg { flex-shrink: 0; opacity: .9; }
    .menu-item .chevron { margin-left: auto; opacity: 0.65; flex-shrink: 0; }
    #sidebar .menu { position: relative; z-index: 20; }
    .menu-accordion { position: relative; }
    .menu-accordion-panel { display: none; }
    .menu-accordion.open .menu-accordion-panel { display: block; }
    .menu-accordion .menu-item-accordion { width: 100%; }
    .menu-accordion .chevron-accordion {
      transition: transform 0.15s ease;
      transform: rotate(-90deg);
    }
    .menu-accordion.open .chevron-accordion { transform: rotate(0deg); }
    .menu-item-sub { padding-left: 28px; font-size: 0.875rem; }
    .menu-accordion-panel .flyout-wrap.flyout-wrap-sub {
      margin-top: 0;
      padding-top: 0;
      border-top: none;
    }
    .flyout-wrap {
      position: relative; margin-top: 6px; padding-top: 6px; border-top: 1px solid #2a3138;
    }
    .flyout-wrap .flyout-panel {
      display: none;
      position: fixed;
      top: 0;
      bottom: 0;
      left: var(--sidebar-width, 230px);
      width: 288px;
      z-index: 40;
      flex-direction: column;
      margin: 0;
      padding: 0;
      background: linear-gradient(180deg, #323a4a 0%, #232a36 42%, #1a1f28 100%);
      color: #e4e7ec;
      border: none;
      border-left: 1px solid rgba(255,255,255,.08);
      border-right: 1px solid rgba(0,0,0,.35);
      box-shadow: 8px 0 28px rgba(0,0,0,.35);
    }
    /* Fixed panel is outside the wrap’s layout box — moving the cursor can leave the wrap before entering the panel and close the menu. Invisible bridge keeps :hover on .flyout-wrap until the pointer reaches the panel. */
    .flyout-hover-bridge {
      display: none;
      position: fixed;
      top: 0;
      bottom: 0;
      left: var(--sidebar-width, 230px);
      width: 40px;
      z-index: 39;
      pointer-events: auto;
      background: transparent;
    }
    .flyout-wrap.open .flyout-hover-bridge {
      display: block;
    }
    .flyout-wrap.open .flyout-panel { display: flex; }
    .flyout-group-head {
      display: flex; align-items: center; gap: 14px;
      padding: 20px 16px 18px;
      border-bottom: 1px solid rgba(255,255,255,.1);
      background: rgba(0,0,0,.2);
    }
    .flyout-group-icon-wrap {
      flex-shrink: 0; width: 46px; height: 46px; border-radius: 12px;
      display: flex; align-items: center; justify-content: center;
      background: linear-gradient(145deg, #ff9a5c 0%, #eb5202 45%, #c43d00 100%);
      box-shadow: 0 4px 16px rgba(235, 82, 2, 0.45), inset 0 1px 0 rgba(255,255,255,.25);
    }
    .flyout-group-icon-wrap svg { display: block; }
    .flyout-group-title {
      font-size: 0.95rem;
      font-weight: 700;
      letter-spacing: 0.02em;
      color: #fff;
      line-height: 1.25;
    }
    .flyout-group-sub {
      font-size: 0.72rem;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: rgba(255,255,255,.45);
      margin-top: 2px;
    }
    .flyout-items { flex: 1; overflow-y: auto; padding: 10px 0 20px; }
    .flyout-panel.flyout-panel--multi-cols {
      width: min(1040px, calc(100vw - 236px));
    }
    .flyout-items.flyout-items-cols {
      display: flex;
      flex-direction: row;
      align-items: flex-start;
      flex: 1;
      min-height: 0;
      gap: 0;
      overflow-x: auto;
      overflow-y: auto;
      padding: 10px 0 20px;
    }
    .flyout-column {
      flex: 1 1 0;
      min-width: 200px;
      max-width: 360px;
      box-sizing: border-box;
    }
    .flyout-items-cols-3 .flyout-column {
      flex: 1 1 0;
      min-width: 0;
      max-width: none;
    }
    .flyout-column + .flyout-column {
      border-left: 1px solid rgba(255,255,255,.1);
      padding-left: 12px;
      margin-left: 8px;
    }
    .flyout-column > .flyout-subgroup:first-child {
      border-top: none;
      margin-top: 0;
      padding-top: 0;
    }
    .flyout-placeholder {
      padding: 12px 14px 16px;
    }
    .flyout-placeholder-text {
      margin: 8px 0 0;
      font-size: 0.8125rem;
      line-height: 1.45;
      color: rgba(255,255,255,.55);
    }
    .flyout-item {
      display: block; width: 100%; padding: 12px 18px;
      border: none; border-left: 3px solid transparent;
      background: transparent; color: #d2d6de; font-size: 0.9rem; text-align: left;
      cursor: pointer; font-family: inherit; text-decoration: none; box-sizing: border-box;
    }
    .flyout-item:hover { background: rgba(255,255,255,.07); color: #fff; }
    .flyout-item.active {
      background: rgba(235, 82, 2, 0.18); border-left-color: #eb5202;
      font-weight: 600; color: #fff;
    }
    .flyout-subgroup {
      border-top: 1px solid rgba(255,255,255,.1);
      margin-top: 8px;
      padding-top: 6px;
    }
    .flyout-subgroup-label {
      padding: 10px 18px 8px;
      font-size: 0.68rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.11em;
      color: rgba(255,255,255,.38);
    }
    .flyout-item.flyout-item-row {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .flyout-item-row .flyout-item-icon {
      flex-shrink: 0;
      width: 22px;
      height: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: rgba(255,255,255,.55);
    }
    .flyout-item-row .flyout-item-icon svg { display: block; }
    .flyout-item-row:hover .flyout-item-icon,
    .flyout-item-row.active .flyout-item-icon { color: rgba(255,255,255,.92); }
    .search-picker-wrap { position: relative; max-width: 420px; margin-bottom: 10px; }
    .search-picker-list {
      position: absolute; left: 0; right: 0; top: 100%; z-index: 40;
      margin-top: 2px; background: #fff; border: 1px solid #ccc; border-radius: 4px;
      box-shadow: 0 4px 14px rgba(0,0,0,.12); max-height: 10rem; overflow-y: auto;
      display: none;
    }
    .search-picker-list.open { display: block; }
    .search-picker-item {
      display: block; width: 100%; padding: 8px 10px; border: none; background: #fff;
      text-align: left; font-size: 0.85rem; cursor: pointer; border-bottom: 1px solid #eee;
    }
    .search-picker-item:hover { background: #f5f5f5; }
    .search-picker-item--muted { color: #666; font-style: italic; }
    #exercise-library-search .ex-lib-mg-filter-label {
      min-width: 200px;
      flex: 1 1 200px;
      max-width: 320px;
    }
    #exercise-library-search .ex-lib-mg-filter-wrap.search-picker-wrap {
      position: relative;
      width: 100%;
      min-width: 160px;
      max-width: none;
      margin-bottom: 0;
    }
    #exercise-library-search .ex-lib-mg-filter-wrap .ex-multiselect {
      width: 100%;
      min-width: 160px;
      min-height: 34px;
      border-color: #adadad;
      border-radius: 2px;
    }
    #exercise-library-search .ex-lib-mg-filter-wrap .ex-multiselect__search {
      min-width: 72px;
      font-size: 0.875rem;
    }
    .equipment-svg-thumb,
    .equipment-catalog-thumb { width: 40px; height: 40px; object-fit: contain; display: block; }
    .exercise-edit-heading__icon .equipment-catalog-thumb { width: 32px; height: 32px; }
    th.equipment-catalog-icon-th { width: 1%; min-width: 48px; text-align: center; }
    td.equipment-catalog-icon-td { text-align: center; vertical-align: middle; }
    .eq-edit-icon-svg-details { margin-top: 4px; max-width: 640px; border: 1px solid #e2e8f0; border-radius: 8px; padding: 0 12px 12px; background: #fafafa; }
    .eq-edit-icon-svg-details > summary { cursor: pointer; font-weight: 600; padding: 10px 0; list-style-position: outside; }
    .eq-edit-icon-svg-details[open] > summary { margin-bottom: 8px; border-bottom: 1px solid #e2e8f0; }
    .equipment-icon-heading { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
    .equipment-icon-heading svg { width: 44px; height: 44px; color: #334155; flex-shrink: 0; }
    #eq-edit-icon-svg, #ee-icon-svg, #ee-group-icon-svg, textarea[id^="ee-icon-combo-svg-"], textarea[id^="bn-icon-combo-svg-"], #bn-edit-icon-svg, #ec-edit-icon-svg, #ea-edit-icon-svg, #ex-edit-icon-svg { font-family: ui-monospace, monospace; font-size: 0.8rem; min-height: 100px; width: 100%; max-width: 640px; }
    .ee-icon-combination-card, .bn-icon-combination-card { border: 1px solid #d1d5db; border-radius: 8px; padding: 14px 16px 16px; margin-top: 14px; background: #fff; }
    .ee-icon-combination-card__head, .bn-icon-combination-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
    .ee-icon-combination-card__title, .bn-icon-combination-card__title { margin: 0; font-size: 0.95rem; font-weight: 700; }
    .ee-icon-combination-card__remove, .bn-icon-combination-card__remove { flex: 0 0 auto; }
    #eq-edit-icon-preview, #ee-icon-preview, #bn-edit-icon-preview, #ec-edit-icon-preview, #ea-edit-icon-preview, #ex-edit-icon-preview { min-height: 48px; margin-top: 8px; max-width: 120px; }
    .picker-row-inner > .equipment-svg-thumb { flex-shrink: 0; }
    .lang-picker-row { display: flex; align-items: center; gap: 10px; margin: 8px 0; cursor: pointer; flex-wrap: wrap; }
    .lang-picker-row .lang-picker-flag { font-size: 1.35rem; line-height: 1; flex-shrink: 0; }
    .lang-picker-row .lang-picker-text { flex: 1; min-width: 0; }
    .catalog-id-nav-td { font-weight: 600; }
    .catalog-id-nav-link {
      color: #2563eb; text-decoration: underline; cursor: pointer;
    }
    .catalog-id-nav-link:hover { color: #1d4ed8; }
    .catalog-id-nav-td[onclick] { cursor: pointer; color: #2563eb; text-decoration: underline; }
    .catalog-id-nav-td[onclick]:hover { color: #1d4ed8; }
    .chip-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
    .chip {
      display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px;
      background: #eef6ff; border: 1px solid #bcd; border-radius: 999px; font-size: 0.8rem;
    }
    .chip button.chip-remove {
      border: none; background: transparent; cursor: pointer; padding: 0 2px;
      font-size: 1rem; line-height: 1; color: #555;
    }
    .exercise-catalog-link-pane:not(.catalog-ex-link-pane) { max-width: 520px; }
    .exercise-catalog-link-pane:not(.catalog-ex-link-pane) .ex-catalog-selected-block { margin: 12px 0 16px; }
    .catalog-ex-link-pane.exercise-catalog-link-pane { max-width: none; }
    .catalog-ex-link-pane .ex-catalog-selected-block { margin: 0; }
    .exercise-catalog-link-pane .ex-catalog-selected-heading {
      font-size: 0.75rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
      color: #64748b; margin: 0 0 6px;
    }
    .exercise-catalog-link-pane .ex-catalog-selected-list {
      display: flex; flex-direction: column; gap: 0; margin: 0;
      border: 1px solid #e2e8f0; border-radius: 6px; overflow: hidden; background: #fff;
    }
    .exercise-catalog-link-pane .ex-catalog-selected-list:empty::before {
      content: 'None selected';
      display: block; padding: 10px 12px; font-size: 0.875rem; color: #94a3b8; font-style: italic;
    }
    .ex-catalog-selected-item {
      display: flex; align-items: stretch; min-height: 40px;
      border-bottom: 1px solid #e2e8f0;
    }
    .ex-catalog-selected-item:last-child { border-bottom: none; }
    .ex-catalog-selected-item__label {
      flex: 1; min-width: 0; display: flex; align-items: center; padding: 10px 12px;
      font-size: 0.9rem; color: #1e293b; background: #f8fafc;
      border-right: 1px solid #e2e8f0;
    }
    .ex-catalog-selected-item__label .picker-row-inner {
      width: 100%; min-width: 0;
    }
    .ex-catalog-selected-item__open,
    .ex-step-selected-item__open {
      flex: 0 0 44px; width: 44px; margin: 0; padding: 0; border: none; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      color: #2563eb; background: #eff6ff; border-right: 1px solid #e2e8f0;
    }
    .ex-catalog-selected-item__open:hover,
    .ex-step-selected-item__open:hover { background: #dbeafe; color: #1d4ed8; }
    .ex-catalog-selected-item__open svg,
    .ex-step-selected-item__open svg { display: block; }
    .ex-catalog-selected-item__open:disabled {
      cursor: default; opacity: 0.45;
    }
    .ex-catalog-selected-item__remove {
      flex: 0 0 44px; width: 44px; margin: 0; padding: 0; border: none; cursor: pointer;
      font-size: 1.25rem; line-height: 1; font-weight: 600; color: #b91c1c; background: #fef2f2;
    }
    .ex-catalog-selected-item__remove:hover { background: #fee2e2; color: #991b1b; }
    .ex-step-selected-item--deleted { opacity: 0.45; }
    .ex-step-selected-item--deleted .ex-step-selected-item__label {
      text-decoration: line-through; background: #fef2f2;
    }
    .ex-step-selected-item__title {
      display: flex; align-items: center; flex: 1; min-width: 8rem; gap: 6px;
    }
    .ex-step-selected-item__edit-icon {
      display: inline-flex; align-items: center; justify-content: center;
      flex-shrink: 0; color: #64748b; line-height: 0; cursor: text;
    }
    .ex-step-selected-item__edit-icon svg { display: block; }
    .ex-step-selected-item__title-text {
      cursor: text; flex: 1; min-width: 0; font-weight: 500;
    }
    .ex-step-selected-item__title-input {
      flex: 1; min-width: 8rem; font-size: 0.9rem; padding: 4px 8px;
      border: 1px solid #94a3b8; border-radius: 4px; font-weight: 500;
    }
    .ex-step-selected-item__add {
      flex: 0 0 44px; width: 44px; margin: 0; padding: 0; border: none; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      color: #059669; background: #ecfdf5; border-right: 1px solid #e2e8f0;
    }
    .ex-step-selected-item__add:hover { background: #d1fae5; color: #047857; }
    .ex-step-selected-item__add svg { display: block; }
    .ex-step-add-wrap { margin-top: 0; }
    .ex-step-add-row {
      display: flex; align-items: stretch; min-height: 40px;
      border: 1px solid #e2e8f0; border-top: none; border-radius: 0 0 6px 6px;
      background: #fff; overflow: hidden;
    }
    .ex-steps-selected-list:not(:empty) + .ex-step-add-wrap .ex-step-add-row {
      border-top: 1px solid #e2e8f0;
    }
    .ex-step-add-row__fill {
      flex: 1; min-width: 0; background: #f8fafc; border-right: 1px solid #e2e8f0;
    }
    .ex-step-add-row__slot {
      flex: 0 0 44px; width: 44px; background: #f8fafc;
      border-right: 1px solid #e2e8f0;
    }
    .ex-step-add-row__slot:last-child { border-right: none; }
    .exercise-catalog-link-pane .ex-catalog-search-wrap {
      margin-top: 8px; max-width: none; width: 100%; margin-bottom: 0;
    }
    .exercise-catalog-link-pane .ex-catalog-search-wrap input[type="text"] {
      width: 100%; box-sizing: border-box; display: block;
    }
    .exercise-catalog-link-pane .ex-catalog-search-wrap .search-picker-list {
      width: 100%; box-sizing: border-box; left: 0; right: 0;
    }
    .exercise-edit-heading {
      font-weight: 400;
      font-size: 1.5rem;
      line-height: 1.3;
    }
    .exercise-edit-heading .exercise-edit-heading__inner {
      display: inline-flex; align-items: center; gap: 10px; flex-wrap: wrap;
    }
    .exercise-edit-heading .exercise-edit-heading__text {
      display: inline-flex; align-items: center; flex-wrap: wrap; gap: 0.25em;
    }
    .exercise-edit-heading .exercise-edit-heading__prefix {
      font-size: inherit;
      font-weight: 400;
      color: #64748b;
    }
    .exercise-edit-heading .exercise-edit-heading__name {
      font-size: inherit;
      font-weight: 600;
      color: #1a1a1a;
    }
    .exercise-edit-heading .exercise-edit-heading__id {
      font-size: 0.875rem;
      font-weight: 400;
      color: #94a3b8;
    }
    .exercise-edit-heading .exercise-edit-heading__icon {
      display: inline-flex; align-items: center; justify-content: center; line-height: 0;
      flex-shrink: 0; margin-top: -2px;
    }
    .ex-steps-selected-list .ex-step-selected-item__drag {
      flex: 0 0 44px; width: 44px; display: flex; align-items: center; justify-content: center;
      margin: 0; padding: 0; border: none; cursor: grab; user-select: none;
      font-size: 1.1rem; line-height: 1; color: #64748b; background: #f1f5f9;
      border-right: 1px solid #e2e8f0;
    }
    .ex-step-selected-item.ex-step-dragging { opacity: 0.55; }
    .ex-step-selected-item__label-inner {
      display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 14px; width: 100%; min-width: 0;
    }
    .ex-step-selected-item__field { white-space: nowrap; }
    .ex-step-selected-item__field strong { font-weight: 600; color: #475569; margin-right: 4px; }
    .muscle-catalog-icon { display: inline-flex; vertical-align: middle; line-height: 0; }
    .muscle-catalog-icon svg { display: block; }
    .muscle-catalog-wrap { display: inline-flex; align-items: center; vertical-align: middle; line-height: 0; }
    .muscle-catalog-wrap--grid-dual { gap: 3px; }
    .muscle-catalog-img {
      display: block;
      width: 28px;
      height: 28px;
      object-fit: cover;
      object-position: top center;
    }
    .picker-row-inner { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; }
    .picker-row-inner .muscle-catalog-wrap { flex-shrink: 0; }
    .muscle-select-icon-preview { display: inline-flex; align-items: center; min-height: 28px; }
    .icon-picker-grid {
      display: flex; flex-wrap: wrap; gap: 6px; max-height: 200px; overflow: auto;
      margin-top: 10px; padding: 8px; border: 1px solid #ddd; border-radius: 4px; background: #fafafa;
    }
    .icon-pick-tile {
      padding: 4px; border: 1px solid #ccc; border-radius: 4px; background: #fff; cursor: pointer; line-height: 0;
    }
    .icon-pick-tile:hover { border-color: #eb5202; }
    .exercise-chip-inner { display: inline-flex; align-items: center; gap: 6px; }
    /* Detail tabs: see admin-detail-nav.css (merged into shell.css) */
    .tab-submenu-layout { display: flex; align-items: flex-start; margin-top: 10px; }
    .tab-submenu-layout:not(.admin-detail-layout) { gap: 18px; }
    .tab-submenu-layout:not(.admin-detail-layout) > .tab-submenu-panes { flex: 1; min-width: 0; }
    .exercise-edit-steps-wrap { margin-top: 4px; }
    .exercise-edit-steps-wrap .muted { margin-bottom: 8px; }
    table.exercise-edit-steps-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
    table.exercise-edit-steps-table th,
    table.exercise-edit-steps-table td { padding: 6px 8px; text-align: left; border-bottom: 1px solid #e3e3e3; vertical-align: top; }
    table.exercise-edit-steps-table th { font-weight: 600; background: #f7f7f7; }
    table.exercise-edit-steps-table tr[data-step-id] { cursor: grab; }
    table.exercise-edit-steps-table tr.ex-step-dragging { opacity: 0.55; }
    table.exercise-edit-steps-table .ex-step-drag-handle { width: 2rem; text-align: center; cursor: grab; user-select: none; color: #888; }
    table.exercise-edit-steps-table td.ex-step-desc { max-width: 28rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .workout-edit-exercises-wrap { margin-top: 4px; max-width: min(100%, 72rem); width: 100%; }
    .workout-edit-exercises-hint { color: #666; font-size: 0.9rem; margin: 0 0 12px; }
    .workout-edit-exercises-toolbar { margin-bottom: 12px; }
    ul.workout-edit-exercises-list { list-style: none; margin: 0; padding: 0; border: 1px solid #e3e3e3; border-radius: 6px; background: #fff; }
    ul.workout-edit-exercises-list:empty { border: none; }
    li.workout-edit-exercise-item {
      display: flex; flex-direction: column; align-items: stretch; gap: 0;
      padding: 0; border-bottom: 1px solid #eee; cursor: default;
    }
    li.workout-edit-exercise-item:last-child { border-bottom: none; }
    li.workout-edit-exercise-item.workout-ex-dragging { opacity: 0.55; }
    .workout-edit-exercise-drag { flex: 0 0 auto; color: #888; user-select: none; width: 1.5rem; text-align: center; cursor: grab; }
    .workout-edit-exercise-body { flex: 1 1 auto; min-width: 0; cursor: pointer; }
    button.workout-edit-exercise-view { flex: 0 0 auto; margin-left: 4px; }
    .workout-edit-exercise-dates {
      flex: 0 0 auto;
      margin-left: auto;
      font-size: 0.8rem;
      color: #666;
      white-space: nowrap;
      padding: 0 4px;
    }
    .workout-edit-exercise-name { font-weight: 500; }
    .workout-edit-exercise-meta { color: #666; font-size: 0.88rem; margin-left: 6px; }
    button.workout-edit-exercise-remove { flex: 0 0 auto; border: none; background: transparent; color: #b42318; font-size: 1.25rem; line-height: 1; cursor: pointer; padding: 2px 6px; border-radius: 4px; }
    button.workout-edit-exercise-remove:hover { background: #fef3f2; }
    .workout-edit-exercise-head { display: flex; align-items: center; gap: 10px; padding: 10px 12px; }
    li.workout-edit-exercise-item.workout-ex-dragging .workout-edit-exercise-drag { cursor: grabbing; }
    button.workout-edit-exercise-toggle { flex: 0 0 auto; border: none; background: transparent; color: #444; font-size: 0.85rem; cursor: pointer; padding: 2px 6px; border-radius: 4px; }
    button.workout-edit-exercise-toggle:hover { background: #f0f0f0; }
    button.workout-edit-exercise-toggle[aria-expanded="true"] { transform: rotate(90deg); }
    .workout-edit-exercise-details { padding: 0 12px 12px 2.75rem; border-top: 1px solid #f0f0f0; background: #fafafa; }
    .workout-edit-exercise-details.hidden { display: none; }
    .workout-edit-exercise-fields {
      display: grid;
      grid-template-columns: repeat(7, minmax(0, 1fr));
      gap: 10px 14px;
      margin-top: 10px;
    }
    .prog-ex-row-images-notes {
      grid-column: 1 / -1;
      display: grid;
      grid-template-columns: 5.5rem 1fr 1fr;
      gap: 10px 14px;
      align-items: start;
    }
    .prog-ex-images-field {
      display: flex;
      flex-direction: column;
      gap: 4px;
      min-width: 0;
    }
    .prog-ex-images-placeholder {
      box-sizing: border-box;
      width: 5.5rem;
      height: 5.5rem;
      aspect-ratio: 1;
      padding: 8px;
      border: 1px dashed #ccc;
      border-radius: 6px;
      background: #fff;
      color: #666;
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
    }
    .prog-ex-images-placeholder-text {
      margin: 0;
      font-size: 0.72rem;
      line-height: 1.35;
    }
    .prog-ex-field-notes,
    .prog-ex-field-meta {
      display: flex;
      flex-direction: column;
      gap: 4px;
      min-width: 0;
    }
    .workout-edit-exercise-fields label { display: flex; flex-direction: column; gap: 4px; font-size: 0.8rem; color: #555; min-width: 0; }
    .prog-ex-field-label {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 0.8rem;
      color: #555;
      line-height: 1.2;
    }
    .prog-ex-field-icon { flex: 0 0 auto; color: #666; opacity: 0.9; }
    .workout-edit-exercise-fields input,
    .workout-edit-exercise-fields textarea { font-size: 0.9rem; padding: 6px 8px; width: 100%; box-sizing: border-box; }
    .prog-ex-field-notes textarea,
    .prog-ex-field-meta textarea {
      flex: 1 1 auto;
      min-height: 5.5rem;
      height: 5.5rem;
      resize: vertical;
    }
    @media (max-width: 1100px) {
      .workout-edit-exercise-fields { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    }
    @media (max-width: 900px) {
      .workout-edit-exercise-fields { grid-template-columns: repeat(3, minmax(0, 1fr)); }
      .prog-ex-row-images-notes {
        grid-template-columns: 1fr;
      }
      .prog-ex-images-placeholder {
        width: 100%;
        max-width: 8rem;
      }
    }
    .modal-dialog.prog-ex-add-modal { max-width: 640px; width: min(96vw, 640px); }
    .modal-dialog.prog-ex-add-modal .search-picker-wrap { max-width: none; }
    .modal-dialog.prog-ex-add-modal .search-picker-list {
      position: relative; left: auto; right: auto; top: auto;
      max-height: min(52vh, 360px); margin-top: 8px;
    }
    .customer-tab-pane,
    .admin-tab-pane { display: none; margin-top: 0; }
    .customer-tab-pane.active,
    .admin-tab-pane.active { display: block; }
    .customer-tab-placeholder { color: #666; font-size: 0.9rem; line-height: 1.55; max-width: 560px; padding: 8px 0 16px; }
    .cms-pb-split { display: flex; gap: 16px; align-items: flex-start; flex-wrap: wrap; }
    .cms-pb-editor-col { flex: 1 1 320px; min-width: 0; max-height: 70vh; overflow: auto; }
    .cms-pb-preview-col { flex: 1 1 280px; min-width: 0; border: 1px solid #e3e3e3; border-radius: 6px; padding: 10px; background: #fafafa; max-height: 70vh; overflow: auto; }
    .cms-pb-preview-title { margin: 0 0 8px; font-size: 0.95rem; }
    .cms-pb-toolbar { margin-bottom: 12px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
    .cms-pb-edit-row { border: 1px solid #ddd; border-radius: 6px; padding: 10px; margin-bottom: 12px; background: #fff; }
    .cms-pb-edit-row-head { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 8px; }
    .cms-pb-edit-cols { display: flex; flex-wrap: wrap; gap: 12px; }
    .cms-pb-edit-col { flex: 1 1 220px; min-width: 180px; border: 1px dashed #ccc; border-radius: 4px; padding: 8px; background: #fcfcfc; }
    .cms-pb-edit-col-head { font-size: 0.85rem; margin-bottom: 8px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
    .cms-pb-block { border: 1px solid #e3e3e3; border-radius: 4px; padding: 8px; margin-bottom: 8px; background: #fff; }
    .cms-pb-block-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; font-size: 0.8rem; }
    .cms-pb-block-body label { display: block; margin-top: 6px; font-size: 0.85rem; }
    .cms-pb-tabs-edit { margin-top: 6px; padding: 8px; background: #f7f7f7; border-radius: 4px; }
    .cms-pb-tab-pane-edit { margin-top: 8px; padding: 8px; border: 1px solid #ddd; border-radius: 4px; background: #fff; }
    .cms-pb-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-start; margin-bottom: 12px; }
    .cms-pb-tab-labels { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
    .cms-pb-tab-label { padding: 6px 10px; border: 1px solid #ccc; border-radius: 4px; background: #fff; cursor: pointer; font-size: 0.85rem; }
    .cms-pb-tab-label.is-active { border-color: #eb5202; background: #fff3eb; font-weight: 600; }
    .cms-pb-tab-panel { display: none; }
    .cms-pb-tab-panel.is-active { display: block; }
    .cms-pb-btn { display: inline-block; margin: 4px 8px 4px 0; padding: 8px 14px; border-radius: 4px; text-decoration: none; font-size: 0.9rem; }
    .cms-pb-btn-primary { background: #eb5202; color: #fff; border: 1px solid #c2410c; }
    .cms-pb-btn-secondary { background: #f3f4f6; color: #111; border: 1px solid #d1d5db; }
    .cms-pb-btn-link { background: transparent; color: #2563eb; border: none; text-decoration: underline; }
    .cms-pb-divider { border: none; border-top: 1px solid #e5e5e5; margin: 12px 0; }
    .cms-pb-media img { max-width: 100%; height: auto; border-radius: 4px; }
    .cms-pb-asset-flyout { margin-top: 12px; padding: 12px; border: 1px solid #eb5202; border-radius: 6px; background: #fffaf5; }
    .cms-pb-asset-flyout-inner { font-size: 0.9rem; }
    .config-page-header {
      display: flex; align-items: center; justify-content: space-between;
      gap: 16px; margin-bottom: 0; padding-bottom: 12px;
      border-bottom: 1px solid #e3e3e3;
    }
    .config-page-header h2 {
      margin: 0; font-size: 1.35rem; font-weight: 400; color: #303030;
    }
    .config-page-save.btn-primary {
      background: #eb5202; border-color: #eb5202; padding: 7px 18px;
      font-weight: 600; letter-spacing: 0.01em;
    }
    .config-page-save.btn-primary:hover { background: #d94802; border-color: #d94802; }
    .config-email-sections { display: flex; flex-direction: column; gap: 20px; padding: 12px 16px 16px; }
    .config-email-section__title {
      margin: 0 0 10px; font-size: 0.9375rem; font-weight: 700; color: #303030;
      text-transform: uppercase; letter-spacing: 0.03em;
    }
    .config-email-section { padding-bottom: 4px; border-bottom: 1px solid #ececec; }
    .config-email-section:last-child { border-bottom: none; padding-bottom: 0; }
    .grid-actions-btns { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
    .grid-actions-btns .btn-small.btn-danger {
      color: #b91c1c; border-color: #fecaca; background: #fef2f2;
    }
    .grid-actions-btns .btn-small.btn-danger:hover { border-color: #f87171; background: #fee2e2; }
    .config-tree-layout { display: flex; align-items: flex-start; gap: 16px; margin-top: 0; }
    .config-tree-nav {
      width: 260px; flex-shrink: 0;
      border: 1px solid #e3e3e3;
      background: #fff; padding: 0; user-select: none;
    }
    .config-tree-content {
      flex: 1; min-width: 0; border: 1px solid #e3e3e3;
      background: #fff; padding: 0;
    }
    #base-configuration-pane-exercises .exercise-lookup-grid-pane {
      padding: 12px 16px 16px;
    }
    #base-configuration-pane-exercises .exercise-lookup-grid-pane .grid-toolbar.wide {
      margin-bottom: 4px;
    }
    #app-modal-footer .btn-danger { margin-left: auto; }
    .config-tree-node { border-bottom: 1px solid #e8e8e8; }
    .config-tree-node:last-child { border-bottom: none; }
    .config-tree-item {
      display: flex; align-items: center; gap: 10px; width: 100%;
      padding: 12px 16px; border: none; background: none;
      cursor: pointer; font-family: inherit; font-size: 0.9375rem;
      color: #303030; text-align: left; border-left: 4px solid transparent;
      transition: background .15s, border-color .15s;
    }
    .config-tree-item:hover { background: #f5f5f5; }
    .config-tree-branch .config-tree-label {
      flex: 1; text-transform: uppercase; font-weight: 700;
      font-size: 0.8125rem; letter-spacing: 0.04em; color: #514943;
    }
    .config-tree-branch.expanded { background: #f5f5f5; }
    .config-tree-branch.active { background: #f5f5f5; }
    .config-tree-leaf.active {
      background: #fff; border-left-color: #eb5202;
      font-weight: 600; color: #303030;
    }
    .config-tree-branch .config-tree-arrow {
      flex-shrink: 0; margin-left: auto; opacity: .55;
      transition: transform .2s;
    }
    .config-tree-branch.expanded .config-tree-arrow { transform: rotate(90deg); }
    .config-tree-icon { flex-shrink: 0; opacity: .7; }
    .config-tree-leaf.active .config-tree-icon { opacity: 1; color: #eb5202; }
    .config-tree-children { background: #fafafa; border-top: 1px solid #e8e8e8; padding-left: 0; }
    .config-tree-children .config-tree-leaf {
      padding: 11px 16px; font-size: 0.9375rem; font-weight: 400;
      border-left-width: 4px;
    }
    .config-scope-panel { border: none; }
    .config-scope-panel__head {
      display: flex; align-items: center; justify-content: space-between;
      gap: 12px; padding: 14px 20px; border-bottom: 1px solid #e3e3e3;
      background: #fafafa;
    }
    .config-scope-panel__title {
      margin: 0; font-size: 1rem; font-weight: 700; color: #303030;
    }
    .config-scope-panel__toggle {
      display: inline-flex; align-items: center; justify-content: center;
      width: 28px; height: 28px; padding: 0; border: 1px solid #adadad;
      border-radius: 50%; background: #fff; cursor: pointer; color: #666;
      flex-shrink: 0;
    }
    .config-scope-panel__toggle:hover { border-color: #eb5202; color: #eb5202; }
    .config-scope-panel.is-collapsed .config-scope-panel__toggle svg { transform: rotate(180deg); }
    .config-tree-content.is-payment-view > .config-scope-panel > .config-scope-panel__head { display: none; }
    .config-tree-content.is-payment-view > .config-scope-panel > .config-scope-panel__body { padding: 0; }
    .config-tree-content.is-payment-view #base-configuration-customer-payment-message:not(:empty) {
      padding: 12px 20px 0; font-size: 0.875rem;
    }
    .config-tree-content.is-payment-view #base-configuration-customer-payment-message.error { color: #b91c1c; }
    .config-provider-list { border-top: 1px solid #e3e3e3; }
    .config-provider-list .config-provider-item {
      border-bottom: 1px solid #e3e3e3;
      margin: 0;
    }
    .config-provider-list .config-provider-item__head {
      background: #fff;
      padding: 15px 20px;
      border-bottom: none;
      cursor: pointer;
      user-select: none;
    }
    .config-provider-list .config-provider-item__head:hover { background: #f8f8f8; }
    .config-provider-list .config-provider-item__head:focus-visible {
      outline: 2px solid #eb5202;
      outline-offset: -2px;
    }
    .config-provider-list .config-provider-item:not(.is-collapsed) .config-provider-item__head {
      border-bottom: 1px solid #e3e3e3;
    }
    .config-provider-list .config-provider-item__body { padding: 0; }
    .config-provider-list .config-provider-item .config-scope-field {
      border-bottom: none;
      padding: 16px 20px 20px;
    }
    .config-scope-panel__body { padding: 8px 0 16px; }
    .config-scope-panel__body [id$="-message"]:not(:empty) {
      padding: 12px 20px 0; font-size: 0.875rem;
    }
    .config-scope-panel__body [id$="-message"].error { color: #b91c1c; }
    .config-visuals-hint,
    .config-scope-panel__body > .config-visuals-hint,
    .config-scope-panel__body > p.config-visuals-hint,
    .config-visuals-rows > .config-visuals-hint {
      margin: 20px 20px 12px; max-width: 720px;
      padding-top: 4px; color: #888; font-size: 13px; line-height: 1.5;
    }
    .config-country-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
      gap: 6px 12px;
      max-height: 280px;
      overflow: auto;
      margin-top: 8px;
      padding: 10px 12px;
      border: 1px solid #d1d1d1;
      border-radius: 4px;
      background: #fff;
      width: 100%;
    }
    .config-country-grid__item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      color: #303030;
      line-height: 1.3;
    }
    .config-country-grid__item input {
      margin: 0;
      flex-shrink: 0;
    }
    .config-scope-panel__empty {
      margin: 0; padding: 24px 20px; color: #888; font-size: 0.875rem;
    }
    .config-scope-field {
      display: grid;
      grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
      gap: 8px 20px; align-items: start;
      padding: 18px 20px; border-bottom: 1px solid #e8e8e8;
    }
    .config-scope-field:last-child { border-bottom: none; }
    .config-scope-field__label-col { align-self: center; }
    .config-scope-field__value-col { min-width: 0; }
    .config-scope-field__label {
      display: block; font-weight: 600; font-size: 0.875rem; color: #303030;
      line-height: 1.35;
    }
    .config-scope-field__control {
      display: flex; align-items: flex-start; flex-wrap: wrap;
      gap: 8px 10px; min-width: 0; width: 100%;
    }
    #base-configuration-visuals-pane-defaults .config-scope-field__control {
      flex-direction: column; align-items: stretch;
    }
    .config-scope-field__path {
      margin-top: 8px; font-size: 0.75rem; color: #888;
    }
    .config-scope-field__path code {
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      font-size: 0.72rem; color: #666; word-break: break-all;
    }
    #base-configuration-pane-visuals .config-visuals-rows,
    #base-configuration-pane-visuals [id^="base-configuration-visuals-pane-"] {
      margin: 0; padding: 0;
    }
    .config-visuals-rows { padding: 0; }
    .config-visuals-inline-row { display: contents; }
    .config-visuals-inline-label { display: none; }
    .config-visuals-inline-value {
      font-size: 0.8125rem; color: #555; width: 100%;
    }
    .config-visuals-inline-value .btn-small { margin-left: 8px; }
    .config-visuals-inline-search {
      width: 100%; max-width: 100%; margin-bottom: 0;
    }
    .config-visuals-inline-search input {
      width: 100%; font-size: 0.875rem; padding: 8px 10px;
      border: 1px solid #adadad; border-radius: 2px; box-sizing: border-box;
    }
    .config-visuals-inline-input {
      flex: 1 1 100%; min-width: 0; max-width: none; width: 100%;
      font-size: 0.875rem; padding: 8px 10px;
      border: 1px solid #adadad; border-radius: 2px;
      box-sizing: border-box; background: #fff;
    }
    select.config-visuals-inline-input { max-width: 320px; }
    .config-visuals-divider { display: none; }
    .config-visuals-color-picker {
      width: 44px; height: 36px; padding: 2px; border: 1px solid #adadad;
      border-radius: 2px; cursor: pointer; flex-shrink: 0;
    }
    #base-configuration-admin-pane-translation .config-scope-panel__body {
      padding: 16px 20px 20px;
    }
    #base-configuration-admin-pane-translation h3 {
      margin: 0 0 8px; font-size: 0.9375rem; font-weight: 600;
    }
    .admin-form__label--with-icon,
    .admin-label-with-icon {
      display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap;
    }
    .admin-form__label-catalog-icon { display: inline-flex; align-items: center; line-height: 0; }
    .admin-form__label-catalog-icon .catalog-sex-icon { display: inline-flex; align-items: center; vertical-align: middle; }
    .catalog-images-form { max-width: 520px; }
    .catalog-images-form.catalog-images-grid {
      display: grid;
      grid-template-columns: 5.25rem minmax(0, 1fr) minmax(0, 1fr);
      gap: 10px 14px;
      max-width: 720px;
      align-items: center;
    }
    .catalog-images-grid__corner { grid-column: 1; }
    .catalog-images-grid__col-head {
      font-weight: 600;
      font-size: 0.875rem;
      display: flex;
      align-items: center;
      gap: 6px;
      padding-bottom: 6px;
      border-bottom: 1px solid #e5e5e5;
      margin-bottom: 2px;
    }
    .catalog-images-grid__col-icon { display: inline-flex; align-items: center; line-height: 0; }
    .catalog-images-grid__row-head {
      font-size: 0.75rem;
      font-weight: 600;
      color: #666;
      align-self: center;
    }
    .catalog-image-slot__row {
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 6px;
      flex-wrap: nowrap;
    }
    .catalog-image-thumb {
      position: relative;
      width: 40px;
      height: 40px;
      min-width: 40px;
      min-height: 40px;
      flex-shrink: 0;
    }
    .catalog-image-thumb > a.catalog-image-preview,
    .catalog-image-thumb > .catalog-image-preview-empty {
      position: absolute;
      top: 0;
      left: 0;
      width: 40px;
      height: 40px;
      min-width: 40px;
      min-height: 40px;
      margin: 0;
      box-sizing: border-box;
    }
    .catalog-image-thumb > .catalog-image-preview-empty.hidden {
      display: none !important;
    }
    .catalog-image-thumb > a.catalog-image-preview {
      padding: 4px;
    }
    .catalog-image-slot__row > .catalog-crop-pct-box,
    .catalog-image-slot__row > .btn-icon.catalog-crop-regen-btn {
      width: 40px;
      height: 40px;
      min-width: 40px;
      min-height: 40px;
      flex-shrink: 0;
      box-sizing: border-box;
    }
    .catalog-image-field .admin-form__control {
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }
    a.catalog-image-preview {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1px solid #ccc;
      border-radius: 4px;
      padding: 4px;
      background: #fff;
      line-height: 0;
      cursor: pointer;
      flex-shrink: 0;
    }
    a.catalog-image-preview:hover { border-color: #eb5202; }
    a.catalog-image-preview.hidden { display: none; }
    a.catalog-image-preview img {
      display: block;
      width: 40px;
      height: 40px;
      max-width: 40px;
      max-height: 40px;
      object-fit: contain;
      object-position: top center;
    }
    a.catalog-image-preview object.catalog-image-preview-svg {
      display: block;
      width: 40px;
      height: 40px;
      max-width: 40px;
      max-height: 40px;
      object-position: top center;
      border: 0;
      padding: 0;
      pointer-events: none;
    }
    a.catalog-image-preview object.catalog-image-preview-svg.hidden,
    a.catalog-image-preview img.hidden {
      display: none;
    }
    .catalog-image-preview-empty {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
      border: 1px solid #d1d5db;
      border-radius: 4px;
      background: #f3f4f6;
      font-size: 0.6875rem;
      font-weight: 600;
      color: #9ca3af;
      font-style: normal;
      letter-spacing: 0.02em;
      flex-shrink: 0;
      line-height: 1;
      user-select: none;
    }
    .catalog-image-preview-empty.hidden { display: none; }
    .catalog-image-preview-empty.catalog-image-preview-na {
      color: #9ca3af;
    }
    .catalog-image-row-assets {
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }
    .catalog-image-row-assets .catalog-image-preview-empty {
      margin: 0;
    }
    .catalog-crop-inline-row {
      display: inline-flex;
      flex-direction: row;
      align-items: center;
      gap: 6px;
      flex-wrap: nowrap;
      margin-top: 0;
      flex: 0 0 auto;
    }
    .catalog-image-field .admin-form__control .catalog-crop-inline-row {
      margin-top: 0;
    }
    .catalog-crop-pct-box {
      position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .catalog-image-slot__row .catalog-crop-pct-box .catalog-crop-pct-input {
      width: 100%;
      height: 100%;
      min-width: 0;
      max-width: none;
      padding: 0 10px 0 0;
      font-size: 0.6875rem;
      line-height: 40px;
      text-align: center;
      box-sizing: border-box;
      font-variant-numeric: tabular-nums;
      border: 1px solid #d1d5db;
      border-radius: 4px;
      background: #fff;
      -moz-appearance: textfield;
      appearance: textfield;
    }
    .catalog-crop-pct-box--mirror .catalog-crop-pct-input--mirror {
      background: #f9fafb;
      color: #6b7280;
      cursor: default;
    }
    .catalog-crop-pct-box .catalog-crop-pct-suffix {
      position: absolute;
      right: 2px;
      top: 50%;
      transform: translateY(-50%);
      font-size: 0.5rem;
      color: var(--text-muted, #888);
      pointer-events: none;
      line-height: 1;
    }
    .catalog-crop-pct-input {
      width: 28px;
      height: 28px;
      min-width: 28px;
      max-width: 28px;
      padding: 0;
      font-size: 0.625rem;
      line-height: 28px;
      text-align: center;
      box-sizing: border-box;
      font-variant-numeric: tabular-nums;
      -moz-appearance: textfield;
      appearance: textfield;
    }
    .catalog-crop-pct-input::-webkit-outer-spin-button,
    .catalog-crop-pct-input::-webkit-inner-spin-button {
      -webkit-appearance: none;
      margin: 0;
    }
    .catalog-crop-pct-unit {
      font-size: 0.75rem;
      color: var(--text-muted, #888);
      user-select: none;
      flex-shrink: 0;
      line-height: 1;
    }
    .catalog-crop-inline-row .catalog-crop-regen-btn {
      flex-shrink: 0;
    }
    .catalog-crop-inline-row .btn-icon.catalog-crop-regen-btn {
      padding: 4px;
      min-width: 28px;
      min-height: 28px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .catalog-image-slot__row > .btn-icon.catalog-crop-regen-btn {
      padding: 0;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1px solid #d1d5db;
      border-radius: 4px;
      background: #fff;
    }
    .catalog-image-slot__row > .btn-icon.catalog-crop-regen-btn:hover:not(:disabled) {
      border-color: #eb5202;
    }
    .exercise-edit-stack { max-width: 520px; }
    .exercise-edit-stack > label { display: block; margin-top: 12px; font-weight: 600; }
    .exercise-edit-stack > label:first-of-type { margin-top: 0; }
    .exercise-edit-stack > input,
    .exercise-edit-stack > select,
    .exercise-edit-stack > textarea { width: 100%; box-sizing: border-box; }
    .exercise-edit-info-pane { max-width: none; width: 100%; }
    .exercise-edit-created-by-line {
      margin: 12px 0 0;
      font-size: 0.9375rem;
      line-height: 1.4;
      white-space: nowrap;
    }
    .exercise-edit-created-by-line__label { color: #64748b; font-weight: 500; }
    .exercise-edit-created-by-line__value { font-weight: 600; color: #1a1a1a; }
    .exercise-edit-info-columns {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 24px 32px;
      align-items: start;
    }
    @media (max-width: 900px) {
      .exercise-edit-info-columns { grid-template-columns: 1fr; }
    }
    .exercise-edit-stack--info-col { max-width: none; }
    .exercise-edit-weight-row > label {
      display: block;
      margin: 12px 0 6px;
      font-weight: 600;
    }
    .exercise-edit-weight-row:first-child > label { margin-top: 0; }
    .exercise-edit-weight-dual {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr) auto minmax(0, 1fr);
      gap: 4px 8px;
      align-items: center;
      max-width: 280px;
    }
    .exercise-edit-weight-dual__unit {
      font-size: 0.8125rem;
      color: #64748b;
      font-weight: 600;
    }
    .exercise-edit-weight-dual input {
      width: 100%;
      min-width: 0;
      box-sizing: border-box;
    }
    .exercise-edit-info-hint { margin: 4px 0 0; font-size: 0.8125rem; }
    .exercise-edit-info-icon-preview-label {
      margin: 10px 0 6px;
      font-weight: 600;
      font-size: 0.875rem;
      color: #475569;
    }
    .exercise-edit-info-check {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-top: 12px;
      font-weight: 600;
    }
    .exercise-edit-info-check input { margin: 0; width: auto; }
    .exercise-edit-info-col { min-width: 0; }
    #exercise-edit-pane-exercise .ex-edit-icon-svg-details {
      width: 100%;
      max-width: 100%;
      min-width: 0;
      box-sizing: border-box;
    }
    #exercise-edit-pane-exercise .ex-edit-icon-svg-details #ex-edit-icon-svg,
    #exercise-edit-pane-exercise .ex-edit-icon-svg-details #ex-edit-icon-preview {
      width: 100%;
      max-width: 100%;
      min-width: 0;
      box-sizing: border-box;
    }
    .exercise-edit-muscles-row {
      display: flex; flex-wrap: wrap; gap: 24px; margin-top: 20px; align-items: flex-start;
    }
    .exercise-edit-muscles-column {
      flex: 1 1 280px; min-width: 240px; max-width: 520px;
      display: flex; flex-direction: column; gap: 20px;
    }
    .exercise-edit-muscles-col { width: 100%; min-width: 0; }
    .exercise-edit-muscles-column__title {
      margin: 0 0 12px; font-size: 1rem; font-weight: 600;
    }
    .exercise-edit-muscles-col.exercise-catalog-link-pane { max-width: none; }
    .exercise-edit-muscles-col .ex-catalog-selected-block { margin-top: 0; }
    .exercise-edit-all-pane { max-width: none; }
    .exercise-edit-all {
      display: flex; flex-direction: column; gap: 20px;
    }
    .exercise-edit-all__columns {
      display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start;
    }
    @media (max-width: 960px) {
      .exercise-edit-all__columns { grid-template-columns: 1fr; }
    }
    .exercise-edit-all__column {
      display: flex; flex-direction: column; gap: 20px; min-width: 0;
    }
    .exercise-edit-all__intro {
      margin: 0; font-size: 0.875rem; color: #64748b;
    }
    .exercise-edit-all__section {
      border: 1px solid #e2e8f0; border-radius: 8px; background: #fff; overflow: hidden;
    }
    .exercise-edit-all__section-title {
      margin: 0; padding: 12px 16px; font-size: 0.8rem; font-weight: 700;
      letter-spacing: 0.05em; text-transform: uppercase; color: #334155;
      background: #f1f5f9; border-bottom: 1px solid #e2e8f0;
    }
    .exercise-edit-all__section-body { padding: 14px 16px 16px; }
    .exercise-edit-all__subsection-title {
      margin: 16px 0 8px; font-size: 0.75rem; font-weight: 700;
      letter-spacing: 0.04em; text-transform: uppercase; color: #64748b;
    }
    .exercise-edit-all__section-body > .exercise-edit-all__subsection-title:first-child {
      margin-top: 0;
    }
    .exercise-edit-all__grid {
      display: grid; grid-template-columns: minmax(140px, 34%) 1fr;
      gap: 8px 16px; margin: 0;
    }
    .exercise-edit-all__grid dt {
      margin: 0; font-size: 0.875rem; font-weight: 600; color: #475569;
    }
    .exercise-edit-all__grid dd {
      margin: 0; font-size: 0.875rem; color: #0f172a; word-break: break-word;
    }
    .exercise-edit-all__empty { color: #94a3b8; font-style: italic; }
    .exercise-edit-all__status { font-weight: 600; }
    .exercise-edit-all__status--enabled { color: #15803d; }
    .exercise-edit-all__status--disabled { color: #b91c1c; }
    .exercise-edit-all__status--draft { color: #92400e; }
    .exercise-edit-all__chip-list,
    .exercise-edit-all__steps-list {
      list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px;
    }
    .exercise-edit-all__chip-list li,
    .exercise-edit-all__steps-list li {
      display: flex; align-items: center; gap: 10px; padding: 8px 10px;
      border: 1px solid #e2e8f0; border-radius: 6px; background: #f8fafc;
    }
    .exercise-edit-all__list-row-main { flex: 1; min-width: 0; }
    .exercise-edit-all__chip-list .picker-row-inner { align-items: center; }
    .exercise-edit-all__steps-list { counter-reset: ex-all-step; }
    .exercise-edit-all__steps-list li {
      counter-increment: ex-all-step; padding-left: 36px; position: relative;
      font-size: 0.875rem;
    }
    .exercise-edit-all__steps-list li::before {
      content: counter(ex-all-step); position: absolute; left: 10px; top: 50%;
      transform: translateY(-50%); font-weight: 700; color: #64748b; font-size: 0.8rem;
    }
    .exercise-edit-all__open-link {
      flex: 0 0 auto; width: 36px; height: 36px; margin: 0; padding: 0; border: none;
      border-radius: 6px; cursor: pointer; display: flex; align-items: center; justify-content: center;
      color: #2563eb; background: #eff6ff; text-decoration: none;
    }
    .exercise-edit-all__open-link:hover { background: #dbeafe; color: #1d4ed8; }
    .exercise-edit-all__open-link svg { display: block; }
    .exercise-edit-all__image-row {
      display: flex; align-items: center; gap: 10px; justify-content: space-between;
    }
    .exercise-edit-all__image-row-label { flex: 1; min-width: 0; font-size: 0.875rem; color: #0f172a; }
    .exercise-edit-all__media-table {
      width: 100%; border-collapse: collapse; font-size: 0.875rem;
    }
    .exercise-edit-all__media-table th,
    .exercise-edit-all__media-table td {
      text-align: left; padding: 8px 10px; border-bottom: 1px solid #e2e8f0;
    }
    .exercise-edit-all__media-table th { font-weight: 600; color: #475569; background: #f8fafc; }
    .exercise-edit-all__icon-preview { margin-top: 4px; line-height: 0; }
    .catalog-ex-link-selected__row.picker-row-inner { align-items: center; width: 100%; }
    .catalog-ex-link-selected__row .catalog-ex-link-selected__inner {
      display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1;
    }
    .catalog-ex-link-selected__inner {
      display: flex; flex-direction: column; gap: 2px; min-width: 0;
    }
    .exercise-edit-all__chip-list .catalog-ex-link-selected__row { width: 100%; }
    .catalog-ex-link-selected__name { font-weight: 600; color: #0f172a; }
    .catalog-ex-link-selected__id { font-size: 0.85rem; color: #64748b; font-weight: 500; }
    .catalog-ex-link-selected__meta { font-size: 0.8rem; color: #94a3b8; }
    .catalog-ex-link-pane.exercise-catalog-link-pane {
      width: 100%; min-width: 0;
    }
    .catalog-ex-link-toolbar {
      display: flex; align-items: center; justify-content: flex-end; gap: 16px;
      margin: 0 0 12px; flex-wrap: nowrap; width: 100%;
      min-height: 36px;
    }
    .catalog-ex-link-toolbar .catalog-ex-link-total-found {
      margin-right: auto; font-size: 0.8125rem; color: #666; flex-shrink: 0;
    }
    .benefit-edit-all__section-meta {
      font-weight: 400; text-transform: none; letter-spacing: 0; color: #64748b;
      font-size: 0.8rem; margin-left: 8px;
    }
    .catalog-edit-all__exercise-count {
      margin: 0; padding: 12px 14px; background: #f8fafc; border: 1px solid #e2e8f0;
      border-radius: 4px; font-size: 0.9375rem; color: #334155;
    }
    .catalog-edit-all__exercise-count-value {
      font-weight: 700; color: #0f172a;
    }
    .catalog-ex-link-toolbar label.per-page {
      font-size: 0.8125rem; color: #444; display: inline-flex; align-items: center; gap: 8px;
      margin: 0; white-space: nowrap; flex-shrink: 0; line-height: 1; height: 36px;
    }
    .catalog-ex-link-toolbar select.per-page-select {
      height: 36px; padding: 0 10px; font-size: 0.875rem; line-height: 1;
      border: 1px solid #adadad; border-radius: 2px; box-sizing: border-box;
    }
    .catalog-ex-link-toolbar .grid-toolbar-pager {
      margin: 0; display: flex; align-items: center; flex-shrink: 0; height: 36px;
    }
    .catalog-ex-link-toolbar .catalog-ex-link-pagination-inner,
    .catalog-ex-link-toolbar .grid-pagination-inner {
      display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; height: 36px;
    }
    .catalog-ex-link-toolbar .grid-pager-arrow {
      width: 36px; height: 36px; min-width: 36px; min-height: 36px;
    }
    .catalog-ex-link-toolbar .grid-pager-arrow svg { display: block; }
    .catalog-ex-link-toolbar .grid-pager-page-input {
      height: 36px; width: 3.25rem; min-width: 3.25rem; padding: 0 8px;
      font-size: 0.875rem; line-height: 1; box-sizing: border-box;
    }
    .catalog-ex-link-toolbar .grid-pager-of {
      font-size: 0.8125rem; color: #444; white-space: nowrap; line-height: 1;
      display: inline-flex; align-items: center; height: 36px;
    }
    .catalog-ex-link-msg {
      margin: 0 0 10px; min-height: 0; max-width: none;
    }
    .catalog-ex-link-msg.hidden { display: none !important; margin: 0; padding: 0; }
    .catalog-ex-link-columns {
      display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 20px; align-items: start; width: 100%;
    }
    @media (max-width: 960px) {
      .catalog-ex-link-columns { grid-template-columns: 1fr; }
    }
    .catalog-ex-link-col { min-width: 0; }
    .catalog-ex-link-col-title {
      font-size: 0.75rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
      color: #64748b; margin: 0 0 8px;
    }
    .catalog-ex-link-filter-row { margin: 12px 0 0; }
    .catalog-ex-link-pane .ex-catalog-search-wrap { margin-top: 0; width: 100%; }
    .catalog-ex-link-pane .ex-catalog-selected-list { min-height: 48px; }
    .ex-multiselect-wrap .search-picker-list { left: 0; }
    .ex-multiselect {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 6px;
      min-height: 38px;
      padding: 4px 6px;
      border: 1px solid #c7c7c7;
      border-radius: 0;
      background: #fff;
      box-sizing: border-box;
    }
    .ex-multiselect__search {
      border: none !important;
      outline: none;
      flex: 1 1 120px;
      min-width: 120px;
      padding: 4px 2px !important;
      margin: 0 !important;
      box-shadow: none !important;
    }
    .ex-multiselect__tag {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      padding: 2px 6px;
      background: #ececec;
      border-radius: 0;
      font-size: 0.875rem;
    }
    .ex-multiselect__tag-remove {
      border: none;
      background: transparent;
      cursor: pointer;
      padding: 0 2px;
      font-size: 1rem;
      line-height: 1;
      color: #555;
    }
    .picker-row-inner--plain { display: block; padding: 6px 10px; text-align: left; width: 100%; }
    #exercise-edit-pane-exercise select.ex-edit-status-select.ex-edit-status--enabled,
    .exercise-edit-info-pane select.ex-edit-status-select.ex-edit-status--enabled {
      border-color: #15803d !important;
      background-color: #f0fdf4 !important;
      color: #15803d !important;
      font-weight: 600;
    }
    #exercise-edit-pane-exercise select.ex-edit-status-select.ex-edit-status--disabled,
    .exercise-edit-info-pane select.ex-edit-status-select.ex-edit-status--disabled {
      border-color: #b91c1c !important;
      background-color: #fef2f2 !important;
      color: #b91c1c !important;
      font-weight: 600;
    }
    #exercise-edit-pane-exercise select.ex-edit-status-select.ex-edit-status--draft,
    .exercise-edit-info-pane select.ex-edit-status-select.ex-edit-status--draft {
      border-color: #d97706 !important;
      background-color: #fffbeb !important;
      color: #b45309 !important;
      font-weight: 600;
    }
    #exercise-edit-pane-exercise select.ex-edit-visibility-select.ex-edit-visibility--public,
    .exercise-edit-info-pane select.ex-edit-visibility-select.ex-edit-visibility--public {
      border-color: #2563eb !important;
      background-color: #eff6ff !important;
      color: #1d4ed8 !important;
      font-weight: 600;
    }
    #exercise-edit-pane-exercise select.ex-edit-visibility-select.ex-edit-visibility--private,
    .exercise-edit-info-pane select.ex-edit-visibility-select.ex-edit-visibility--private {
      border-color: #7c3aed !important;
      background-color: #f5f3ff !important;
      color: #6d28d9 !important;
      font-weight: 600;
    }
    .menu-item.menu-item-flyout { justify-content: flex-start; }
    #sidebar .sidebar-footer { padding: 12px 16px; border-top: 1px solid #2a3138; font-size: 0.8125rem; color: #aaa; }

    #main { flex: 1; display: flex; flex-direction: column; min-width: 0; background: #fff; }
    #toolbar {
      padding: 0 20px;
      display: flex;
      flex-direction: column;
      align-items: stretch;
      gap: 0;
      border-bottom: 1px solid #e3e3e3;
      background: #fafafa;
      font-size: 0.875rem;
      color: #555;
    }
    .admin-toolbar-row {
      min-height: 52px;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 10px;
    }
    .toolbar-notify-wrap {
      position: relative;
      flex-shrink: 0;
    }
    .toolbar-notify-wrap.hidden { display: none !important; }
    .toolbar-notify-btn {
      position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 38px;
      height: 38px;
      padding: 0;
      cursor: pointer;
      background: #fff;
      border: 1px solid #adadad;
      border-radius: 2px;
      color: #555;
      font-family: inherit;
    }
    .toolbar-notify-btn:hover { border-color: #858585; background: #fafafa; }
    .toolbar-notify-btn__icon { display: block; }
    .toolbar-notify-badge {
      position: absolute;
      top: -4px;
      right: -4px;
      min-width: 18px;
      height: 18px;
      padding: 0 5px;
      border-radius: 999px;
      background: #eb5202;
      color: #fff;
      font-size: 11px;
      font-weight: 700;
      line-height: 18px;
      text-align: center;
      box-shadow: 0 0 0 2px #fafafa;
    }
    .toolbar-notify-badge.hidden { display: none !important; }
    .admin-messaging-strip {
      display: flex;
      flex-direction: column;
      gap: 6px;
      padding: 0 0 10px 0;
    }
    .admin-messaging-strip.hidden { display: none !important; }
    .admin-msg-item {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      padding: 8px 12px;
      border-radius: 6px;
      border: 1px solid transparent;
      cursor: pointer;
      line-height: 1.4;
      font-size: 0.8125rem;
      text-align: left;
    }
    .admin-msg-item:hover { filter: brightness(0.98); }
    .admin-msg-item:focus { outline: 2px solid #eb5202; outline-offset: 2px; }
    .admin-msg-item .admin-msg-type {
      flex-shrink: 0;
      font-weight: 700;
      text-transform: capitalize;
      font-size: 0.68rem;
      letter-spacing: 0.04em;
      opacity: 0.9;
    }
    .admin-msg-item .admin-msg-body { flex: 1; min-width: 0; }
    .admin-msg-item .admin-msg-detail {
      display: block;
      margin-top: 4px;
      font-size: 0.75rem;
      opacity: 0.88;
      word-break: break-word;
    }
    .admin-msg-dismiss-hint { flex-shrink: 0; font-size: 0.68rem; opacity: 0.55; align-self: center; white-space: nowrap; }
    .admin-msg-success { background: #ecfdf3; border-color: #86efac; color: #14532d; }
    .admin-msg-error { background: #fef2f2; border-color: #fca5a5; color: #7f1d1d; }
    .admin-msg-warning { background: #fff7ed; border-color: #fdba74; color: #7c2d12; }
    .admin-msg-notification { background: #f3f4f6; border-color: #d1d5db; color: #374151; }
    #main-content { flex: 1; padding: 20px 24px; overflow: auto; }
    #sidebar .sidebar-footer .admin-version-badge {
      display: block;
      font-size: 0.75rem;
      color: #9ca3af;
      user-select: none;
      line-height: 1.35;
    }
    .admin-version-badge.hidden { display: none !important; }
    #main-content h2 { margin: 0 0 16px; font-size: 1.25rem; font-weight: 600; color: #303030; }
    .body-visual-preview-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
      gap: 20px;
      margin-top: 12px;
    }
    .body-visual-preview-card {
      border: 1px solid #d1d1d1;
      border-radius: 4px;
      background: #fff;
      padding: 12px 14px;
    }
    .body-visual-preview-card h3 {
      margin: 0 0 10px;
      font-size: 1rem;
      font-weight: 600;
    }
    .body-visual-preview-card .bv-preview-meta {
      font-size: 0.875rem;
      color: #555;
      margin-bottom: 10px;
    }
    .body-visual-preview-card .bv-preview-imgs {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
    }
    .body-visual-preview-card .bv-preview-imgs figure {
      margin: 0;
      flex: 1 1 120px;
      min-width: 100px;
    }
    .body-visual-preview-card .bv-preview-imgs img {
      max-width: 100%;
      height: auto;
      display: block;
      border: 1px solid #e5e5e5;
      border-radius: 2px;
      background: #fafafa;
    }
    .body-visual-preview-card .bv-preview-imgs figcaption {
      font-size: 0.75rem;
      color: #666;
      margin-top: 4px;
    }
    .body-visual-preview-context {
      font-size: 0.875rem;
      color: #555;
      margin: 8px 0 0;
    }
    .body-visual-preview-summary {
      font-size: 0.875rem;
      color: #333;
      margin: 0 0 14px;
      line-height: 1.45;
    }
    .body-visual-preview-summary-sep {
      opacity: 0.45;
      padding: 0 8px;
      font-weight: 400;
    }
    .bv-coords-ui-root .bv-coords-main--map-preview {
      min-height: min(78vh, 840px);
    }
    .bv-coords-ui-root .bv-coords-main--map-preview .bv-coords-map-outer {
      flex: 1;
      min-width: 0;
    }
    #body-visual-coords-embed .body-visual-coords-intro {
      margin-top: 0;
      margin-bottom: 12px;
    }
    #body-visual-coords-embed #bv-coords-app.bv-coords-ui-root,
    #body-visuals-preview-body #bv-preview-coords-app.bv-coords-ui-root {
      width: 100%;
      min-height: min(82vh, 880px);
      border: 1px solid #d1d1d1;
      border-radius: 4px;
      background: #fff;
      color: #303030;
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }
    #body-visuals-preview-body #bv-preview-coords-app.bv-coords-ui-root {
      margin-top: 20px;
    }
    .bv-coords-ui-root .bv-coords-toolbar {
      flex-shrink: 0;
      border-bottom: 1px solid #e0e0e0;
      background: #fafafa;
      font-size: 12px;
    }
    .bv-coords-ui-root .bv-coords-toolbar-inner {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 6px 8px;
      padding: 8px 10px;
    }
    .bv-coords-ui-root .bv-visual-picker-sel { font-size: 0.8125rem; padding: 3px 6px; border: 1px solid #ccc; border-radius: 2px; max-width: 340px; }
    .bv-coords-ui-root .bv-coords-tb-save { margin-left: 8px; }
    .bv-coords-ui-root .bv-coords-tb-lab { color: #888; }
    .bv-coords-ui-root .bv-coords-tb-sep { color: #ccc; margin: 0 2px; }
    .bv-coords-ui-root .bv-coords-tb-btn {
      padding: 4px 10px;
      border: 1px solid #c8c8c8;
      border-radius: 3px;
      background: #fff;
      cursor: pointer;
      font-size: 12px;
    }
    .bv-coords-ui-root .bv-coords-tb-btn:hover { background: #f3f3f3; }
    .bv-coords-ui-root .bv-coords-tb-on {
      border-color: #2a6f9e;
      background: #e8f4fc;
      font-weight: 600;
    }
    .bv-coords-ui-root .bv-coords-tb-hint {
      margin-left: auto;
      color: #777;
      font-size: 11px;
    }
    .bv-coords-ui-root .bv-coords-tb-hint--keys {
      display: inline-flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 4px 6px;
      max-width: min(440px, 100%);
      justify-content: flex-end;
      line-height: 1.35;
    }
    .bv-coords-ui-root .bv-coords-help-more {
      color: #9ca3af;
      font-style: italic;
      font-weight: 400;
    }
    .bv-coords-ui-root .bv-coords-main {
      display: flex;
      flex: 1;
      min-height: 0;
      min-height: 480px;
      align-items: flex-start;
    }
    .bv-coords-ui-root .bv-coords-aside {
      flex-shrink: 0;
      display: flex;
      flex-direction: column;
      min-width: 0;
      background: #fcfcfc;
      border-color: #e8e8e8;
      border-style: solid;
      border-width: 0;
    }
    .bv-coords-ui-root .bv-coords-aside-menu {
      width: 220px;
      border-right-width: 1px;
    }
    .bv-coords-ui-root .bv-coords-aside-panel {
      width: 260px;
      border-left-width: 1px;
      padding: 10px 12px;
      font-size: 12px;
    }
    .bv-coords-ui-root .bv-coords-filter-wrap {
      padding: 8px;
      border-bottom: 1px solid #eee;
    }
    .bv-coords-ui-root .bv-coords-filter {
      width: 100%;
      padding: 6px 8px;
      border: 1px solid #ccc;
      border-radius: 3px;
      font-size: 12px;
      box-sizing: border-box;
    }
    .bv-coords-ui-root .bv-coords-menu {
      flex: 1;
      overflow: auto;
      padding: 6px 4px 10px;
    }
    .bv-coords-ui-root .bv-coords-sec-h {
      position: sticky;
      top: 0;
      padding: 4px 6px;
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      color: #888;
      background: rgba(252, 252, 252, 0.95);
    }
    .bv-coords-ui-root .bv-coords-sec-h.bv-coords-sec-h-btn {
      display: block;
      width: 100%;
      margin: 0 0 2px;
      border: 0;
      cursor: pointer;
      font-family: inherit;
      text-align: left;
    }
    .bv-coords-ui-root .bv-coords-sec-h.bv-coords-sec-h-btn:hover {
      color: #333;
      background: rgba(234, 234, 234, 0.98);
    }
    .bv-coords-ui-root .bv-coords-sec-h.bv-coords-sec-h-btn.bv-coords-sec-h-sel {
      color: #1e3a5f;
      background: rgba(191, 219, 254, 0.95);
      box-shadow: inset 3px 0 0 #2563eb;
    }
    .bv-coords-ui-root .bv-coords-ul { list-style: none; margin: 0; padding: 0; }
    .bv-coords-ui-root .bv-coords-ul.bv-coords-ul-collapsed { display: none; }
    .bv-coords-ui-root .bv-coords-subsec-wrap { list-style: none; margin: 0; padding: 0; }
    .bv-coords-ui-root .bv-coords-subsec-h {
      display: block; width: 100%; text-align: left; padding: 6px 12px 6px 20px;
      border: none; background: #f8f9fa; font-size: 0.8125rem; font-weight: 600; color: #374151;
      cursor: pointer; border-bottom: 1px solid #eee;
    }
    .bv-coords-ui-root .bv-coords-subsec-h:hover { background: #eef2f7; }
    .bv-coords-ui-root .bv-coords-subsec-h-sel {
      background: #ffedd5;
      box-shadow: inset 3px 0 0 #ea580c;
    }
    .bv-coords-ui-root .bv-coords-ul-nested {
      margin: 0 0 4px 0;
      padding: 2px 0 4px 14px;
      border-left: 2px solid #e5e7eb;
    }
    .bv-coords-ui-root .bv-coords-li-item--l3 .bv-coords-li {
      padding-left: 10px;
      font-size: 11px;
    }
    .bv-coords-ui-root .bv-coords-li-item--l3 .bv-coords-li-c {
      padding-left: 2px;
    }
    .bv-coords-ui-root .bv-coords-li {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      width: 100%;
      margin: 2px 0;
      padding: 6px 8px;
      border: 0;
      border-radius: 4px;
      background: transparent;
      cursor: pointer;
      text-align: left;
      font-size: 12px;
      color: #333;
    }
    .bv-coords-ui-root .bv-coords-li:hover { background: #f0f0f0; }
    .bv-coords-ui-root .bv-coords-li-in-grp {
      box-shadow: inset 3px 0 0 rgba(37, 99, 235, 0.45);
      background: rgba(239, 246, 255, 0.65);
    }
    .bv-coords-ui-root .bv-coords-li-sel {
      background: #ffedd5;
      font-weight: 600;
      box-shadow: inset 3px 0 0 #ea580c;
    }
    .bv-coords-ui-root .bv-coords-li-in-grp.bv-coords-li-sel {
      background: #ffedd5;
      box-shadow: inset 3px 0 0 #ea580c;
    }
    .bv-coords-ui-root .bv-coords-li-t { line-height: 1.25; }
    .bv-coords-ui-root .bv-coords-li-c { font-family: ui-monospace, monospace; font-size: 10px; color: #888; margin-top: 2px; }
    .bv-coords-ui-root .bv-coords-map-outer {
      flex: 1;
      min-width: 0;
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      overflow: auto;
      padding: 8px;
      background: #f5f5f5;
    }
    .bv-coords-ui-root .bv-coords-map-inner { max-width: 100%; }
    .bv-coords-ui-root .bv-coords-map-inner--all {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      gap: 14px;
      align-items: flex-start;
      justify-content: flex-start;
      width: 100%;
    }
    .bv-coords-ui-root .bv-coords-map-slab {
      flex: 1 1 220px;
      max-width: min(480px, 100%);
      min-width: 160px;
    }
    .bv-coords-ui-root .bv-coords-slab-cap {
      font-size: 11px;
      font-weight: 600;
      color: #555;
      margin-bottom: 6px;
    }
    .bv-coords-ui-root .bv-coords-img-wrap {
      position: relative;
      display: inline-block;
      max-width: 100%;
    }
    .bv-coords-ui-root .bv-coords-img {
      display: block;
      max-width: 100%;
      height: auto;
      vertical-align: top;
    }
    .bv-coords-ui-root .bv-coords-svg {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      pointer-events: auto;
      touch-action: none;
    }
    .bv-coords-ui-root .bv-poly {
      fill: rgba(255, 255, 255, 0.08);
      stroke: rgba(0, 0, 0, 0.25);
      stroke-width: 1;
      cursor: pointer;
    }
    .bv-coords-ui-root .bv-poly:hover {
      fill: rgba(255, 140, 60, 0.2);
      stroke: rgba(234, 88, 12, 0.7);
      stroke-width: 1.5;
    }
    .bv-coords-ui-root .bv-poly-hl {
      fill: rgba(56, 189, 248, 0.16);
      stroke: rgba(37, 99, 235, 0.75);
      stroke-width: 1.5;
    }
    .bv-coords-ui-root .bv-poly-grp {
      fill: rgba(59, 130, 246, 0.14);
      stroke: rgba(37, 99, 235, 0.55);
      stroke-width: 1.75;
    }
    .bv-coords-ui-root .bv-poly-grp.bv-poly-hl {
      fill: rgba(56, 189, 248, 0.22);
      stroke: rgba(29, 78, 216, 0.8);
      stroke-width: 1.75;
    }
    .bv-coords-ui-root .bv-poly-sel {
      fill: rgba(255, 149, 41, 0.45);
      stroke: #c2410c;
      stroke-width: 2.75;
    }
    .bv-coords-ui-root .bv-poly-grp.bv-poly-sel {
      fill: rgba(255, 149, 41, 0.5);
      stroke: #9a3412;
      stroke-width: 2.75;
    }
    .bv-coords-ui-root .bv-poly-sel.bv-poly-hl {
      fill: rgba(255, 120, 25, 0.5);
      stroke: #9a3412;
      stroke-width: 2.75;
    }
    .bv-coords-ui-root .bv-vertex {
      fill: #fff7ed;
      stroke: #ea580c;
      stroke-width: 2.75;
      cursor: grab;
    }
    .bv-coords-ui-root .bv-coords-panel-h { font-weight: 700; margin: 0 0 4px; }
    .bv-coords-ui-root .bv-coords-panel-sub { color: #666; margin-bottom: 8px; font-size: 11px; }
    .bv-coords-ui-root .bv-coords-panel-hint { color: #777; font-size: 11px; margin: 0 0 8px; }
    .bv-coords-ui-root .bv-coords-lab { display: block; font-weight: 600; margin-bottom: 4px; }
    .bv-coords-ui-root .bv-coords-ta {
      width: 100%;
      box-sizing: border-box;
      font-family: ui-monospace, monospace;
      font-size: 11px;
      padding: 8px;
      border: 1px solid #ccc;
      border-radius: 3px;
      resize: vertical;
    }
    .bv-coords-ui-root .bv-coords-actions { margin-top: 10px; display: flex; gap: 8px; flex-wrap: wrap; }
    .bv-coords-ui-root .bv-coords-actions .btn-primary.btn-small {
      background: #eb5202;
      color: #fff;
      border-color: #c2410c;
      font-weight: 600;
    }
    .bv-coords-ui-root .bv-coords-actions .btn-primary.btn-small:hover:not(:disabled) {
      background: #d24b02;
      border-color: #9a3412;
    }
    .bv-coords-ui-root .bv-coords-actions .btn-primary.btn-small:disabled {
      opacity: 0.6;
      cursor: not-allowed;
      background: #9ca3af;
      border-color: #6b7280;
      color: #fff;
    }
    .bv-coords-ui-root .bv-coords-help {
      margin: 12px 0 0;
      padding: 12px 12px 10px;
      font-size: 12px;
      line-height: 1.45;
      color: #374151;
      background: #f9fafb;
      border: 1px solid #e5e7eb;
      border-radius: 6px;
    }
    .bv-coords-ui-root .bv-coords-help-title {
      font-weight: 700;
      font-size: 11px;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: #6b7280;
      margin: 0 0 8px;
    }
    .bv-coords-ui-root .bv-coords-help-list {
      margin: 0;
      padding: 0 0 0 18px;
      list-style-type: disc;
    }
    .bv-coords-ui-root .bv-coords-help-list li {
      margin: 8px 0;
      padding-left: 2px;
    }
    .bv-coords-ui-root .bv-coords-help-keys {
      display: inline-flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 2px 4px;
      vertical-align: middle;
      margin-right: 2px;
    }
    .bv-coords-ui-root .bv-coords-help-plus {
      font-weight: 700;
      color: #6b7280;
      margin: 0 1px;
      font-size: 11px;
    }
    .bv-coords-ui-root .bv-kbd-grp {
      display: inline-flex;
      align-items: center;
      gap: 2px;
    }
    .bv-coords-ui-root .bv-kbd {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 22px;
      min-width: 22px;
      padding: 2px 6px;
      box-sizing: border-box;
      font-size: 10px;
      font-weight: 600;
      font-family: ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
      color: #1f2937;
      background: linear-gradient(180deg, #fff 0%, #f3f4f6 100%);
      border: 1px solid #d1d5db;
      border-radius: 4px;
      box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
    }
    .bv-coords-ui-root .bv-kbd--ico {
      padding: 2px 5px;
    }
    .bv-coords-ui-root kbd.bv-kbd-char {
      font-family: inherit;
    }
    .bv-coords-ui-root .bv-kbd-svg {
      display: block;
    }
    .bv-coords-ui-root .bv-kbd-or {
      font-size: 10px;
      color: #9ca3af;
      font-weight: 500;
      padding: 0 1px;
      user-select: none;
    }
    .bv-coords-ui-root .bv-coords-muted { padding: 24px; text-align: center; color: #888; }
    .bv-coords-ui-root .bv-coords-err { margin: 16px; }
    .toolbar-user-menu {
      position: relative;
      flex-shrink: 0;
    }
    .toolbar-user-menu-trigger {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 6px 12px;
      max-width: 280px;
      cursor: pointer;
      background: #fff;
      border: 1px solid #adadad;
      border-radius: 2px;
      font-size: 0.875rem;
      color: #444;
      font-family: inherit;
      line-height: 1;
    }
    .toolbar-user-menu-trigger:hover { border-color: #858585; background: #fafafa; }
    .toolbar-user-menu-trigger[aria-expanded="true"] {
      border-color: #007bdb;
      background: #f0f8ff;
    }
    .toolbar-user-menu-icon { display: block; flex-shrink: 0; color: #555; }
    .toolbar-user-menu-name {
      font-size: 0.875rem;
      color: #303030;
      font-weight: 500;
      max-width: 160px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      line-height: 1.2;
    }
    .toolbar-user-menu-caret {
      display: block;
      flex-shrink: 0;
      color: #666;
      transition: transform 0.15s ease;
    }
    .toolbar-user-menu.open .toolbar-user-menu-caret { transform: rotate(180deg); }
    .toolbar-user-menu-panel {
      position: absolute;
      top: calc(100% + 4px);
      right: 0;
      min-width: 160px;
      background: #fff;
      border: 1px solid #c8c8c8;
      border-radius: 2px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
      z-index: 120;
      display: flex;
      flex-direction: column;
      padding: 4px 0;
    }
    .toolbar-user-menu-panel.hidden { display: none !important; }
    .toolbar-user-menu-item {
      display: flex;
      align-items: center;
      gap: 10px;
      width: 100%;
      text-align: left;
      padding: 8px 14px;
      border: none;
      background: transparent;
      font-size: 0.875rem;
      color: #303030;
      cursor: pointer;
      font-family: inherit;
    }
    .toolbar-user-menu-item-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      width: 18px;
      height: 18px;
      color: #555;
    }
    .toolbar-user-menu-item:hover { background: #f0f0f0; }
    .toolbar-user-menu-item--signout {
      border-top: 1px solid #e8e8e8;
      margin-top: 4px;
      padding-top: 10px;
      color: #444;
    }
    table.data { border-collapse: collapse; width: 100%; max-width: none; font-size: 0.875rem; }
    table.data th, table.data td { border: 1px solid #e3e3e3; padding: 10px 12px; text-align: left; }
    table.data th { background: #f8f8f8; font-weight: 600; }
    table.data th.sortable-th { cursor: pointer; user-select: none; white-space: nowrap; }
    table.data th.sortable-th:hover { background: #eeeeee; }
    table.data th.sortable-th .sort-ind { font-size: 0.7rem; opacity: 0.85; margin-left: 2px; }
    table.data tbody tr:nth-child(even) { background: #fcfcfc; }
    table.data th.grid-select-col-th,
    table.data td.grid-select-col { width: 44px; max-width: 56px; text-align: center; vertical-align: middle; padding: 6px 4px; }
    table.data th.grid-select-col-th { min-width: 48px; max-width: 72px; width: auto; overflow: visible; position: relative; z-index: 5; }
    .grid-select-header-inner { display: flex; align-items: center; justify-content: center; gap: 4px; flex-wrap: nowrap; }
    input.grid-header-select-cb-dummy {
      width: 14px; height: 14px; margin: 0; flex-shrink: 0; cursor: default;
      opacity: 0.4; accent-color: #9ca3af;
    }
    .grid-bulk-actions-wrap { position: relative; flex-shrink: 0; }
    .grid-bulk-menu-btn {
      width: 26px; height: 26px; padding: 0; margin: 0;
      border: 1px solid #c5c5c5; border-radius: 4px; background: #fff;
      cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
      color: #555; line-height: 0;
    }
    .grid-bulk-menu-btn:hover { background: #f3f4f6; border-color: #9ca3af; }
    .grid-bulk-menu-btn svg { display: block; }
    .grid-bulk-menu {
      position: absolute; left: 0; top: 100%; margin-top: 4px; z-index: 80;
      min-width: 11rem; max-width: min(20rem, 90vw); list-style: none; margin: 0; padding: 4px 0;
      background: #fff; border: 1px solid #e3e3e3; border-radius: 6px;
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
      text-align: left; font-weight: 400;
    }
    .grid-bulk-menu.hidden { display: none !important; }
    .grid-bulk-menu-item {
      display: block; width: 100%; box-sizing: border-box;
      text-align: left; border: none; background: none; margin: 0;
      padding: 8px 14px; font-size: 0.875rem; font-family: inherit; cursor: pointer;
      font-weight: 400; color: #303030;
    }
    .grid-bulk-menu-item:hover { background: #f3f4f6; }
    table.data th.grid-actions-col-th { font-weight: 600; text-align: left; white-space: nowrap; min-width: 5.5rem; }
    .grid-row-actions-wrap { position: relative; display: inline-block; text-align: left; }
    .grid-row-actions-btn {
      display: inline-flex; align-items: center; justify-content: center;
      min-width: 5.25rem; padding: 4px 10px; font-size: 0.8125rem; font-family: inherit;
      border: 1px solid #c5c5c5; border-radius: 4px; background: #fff; cursor: pointer; color: #444;
    }
    .grid-row-actions-btn:hover { background: #f3f4f6; border-color: #9ca3af; }
    .grid-row-actions-btn-inner { display: inline-flex; align-items: center; justify-content: center; gap: 5px; }
    .grid-row-actions-chevron { flex-shrink: 0; opacity: 0.72; display: block; }
    .grid-row-actions-btn-label { line-height: 1.2; }
    .grid-row-actions-single {
      display: inline-flex; align-items: center; justify-content: center;
      min-width: 4.5rem; padding: 4px 10px; font-size: 0.8125rem; font-family: inherit;
      border: 1px solid #c5c5c5; border-radius: 4px; background: #fff; cursor: pointer; color: #444;
    }
    .grid-row-actions-single:hover { background: #f3f4f6; border-color: #9ca3af; }
    .grid-row-actions-single-danger { color: #b30000; border-color: #d4a0a0; }
    .grid-row-actions-single-danger:hover { background: #fff5f5; border-color: #b30000; }
    .grid-row-actions-menu {
      position: absolute; left: 0; right: auto; top: 100%; margin-top: 4px; z-index: 85;
      min-width: 10rem; max-width: min(18rem, 92vw); list-style: none; margin: 0; padding: 4px 0;
      background: #fff; border: 1px solid #e3e3e3; border-radius: 6px;
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
      font-weight: 400;
    }
    .grid-row-actions-menu.hidden { display: none !important; }
    .grid-row-actions-menu-item {
      display: block; width: 100%; box-sizing: border-box; text-align: left;
      border: none; background: none; margin: 0; padding: 8px 14px;
      font-size: 0.875rem; font-family: inherit; cursor: pointer; font-weight: 400; color: #303030;
    }
    .grid-row-actions-menu-item:hover { background: #f3f4f6; }
    .grid-row-actions-menu-item-danger { color: #b30000; }
    .grid-row-actions-menu-item-danger:hover { background: #fff5f5; }
    .visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
    .btn-refresh { padding: 8px 14px; margin-bottom: 0; cursor: pointer; background: #fff; border: 1px solid #adadad; border-radius: 2px; font-size: 0.875rem; }
    .btn-refresh:hover { border-color: #858585; }
    .placeholder { color: #666; max-width: 560px; line-height: 1.5; }
    .grid-view-intro {
      display: flex;
      flex-wrap: wrap;
      align-items: baseline;
      gap: 6px 14px;
      margin-bottom: 12px;
    }
    .grid-view-intro > h2 { margin: 0; }
    .grid-view-intro-desc {
      margin: 0;
      color: #666;
      font-size: 0.875rem;
      font-weight: 400;
      line-height: 1.45;
      flex: 1 1 12rem;
      max-width: none;
    }
    .grid-view-intro--actions-end {
      flex-wrap: nowrap;
      align-items: center;
      justify-content: space-between;
      gap: 12px 20px;
      max-width: none;
      width: 100%;
      box-sizing: border-box;
    }
    .grid-view-intro--actions-end .grid-view-intro__text {
      display: flex;
      align-items: baseline;
      gap: 6px 14px;
      flex: 1 1 auto;
      min-width: 0;
      overflow: hidden;
    }
    .grid-view-intro--actions-end .grid-view-intro__text > h2 {
      margin: 0;
      flex-shrink: 0;
    }
    .grid-view-intro-desc-wrap {
      position: relative;
      min-width: 0;
      flex: 1 1 auto;
      max-width: 100%;
    }
    .grid-view-intro-desc-wrap .grid-view-intro-desc {
      display: block;
      margin: 0;
      color: #666;
      font-size: 0.875rem;
      font-weight: 400;
      line-height: 1.45;
      max-width: 100%;
    }
    .grid-view-intro-desc-wrap.is-truncated .grid-view-intro-desc {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .grid-view-intro-desc-tip {
      display: none;
      position: absolute;
      left: 0;
      top: calc(100% + 6px);
      z-index: 120;
      max-width: min(32rem, 90vw);
      padding: 8px 12px;
      background: #303030;
      color: #fff;
      font-size: 0.8125rem;
      font-weight: 400;
      line-height: 1.45;
      border-radius: 6px;
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
      white-space: normal;
      pointer-events: none;
    }
    .grid-view-intro-desc-wrap.is-truncated:hover .grid-view-intro-desc-tip,
    .grid-view-intro-desc-wrap.is-truncated:focus-within .grid-view-intro-desc-tip {
      display: block;
    }
    .grid-view-intro__actions {
      display: inline-flex;
      flex-shrink: 0;
      align-items: center;
      gap: 8px;
    }
    .grid-view-intro__actions .btn-filters,
    .grid-view-intro__actions .btn-refresh,
    .grid-view-intro__actions .btn-primary {
      flex-shrink: 0;
    }
    @media (max-width: 720px) {
      .grid-view-intro--actions-end {
        flex-wrap: wrap;
        align-items: flex-start;
      }
      .grid-view-intro--actions-end .grid-view-intro__actions {
        width: 100%;
        justify-content: flex-end;
      }
    }
    .grid-subhead-inline {
      display: flex;
      flex-wrap: wrap;
      align-items: baseline;
      gap: 6px 12px;
      margin-bottom: 10px;
    }
    .grid-subhead-inline > h3 { margin: 0; font-size: 1.05rem; font-weight: 600; color: #303030; }
    #app-users-message, #customer-detail-message, #admin-users-message, #admin-roles-message, #admin-permissions-message, #languages-message, #translation-entries-message, #body-visuals-message, #muscle-groups-message, #muscles-message { margin-bottom: 8px; font-size: 0.875rem; }
    table.data.wide { max-width: none; }
    .asset-thumb {
      width: 44px;
      height: 44px;
      object-fit: contain;
      border: 1px solid #ddd;
      border-radius: 4px;
      background: #fafafa;
      display: block;
    }
    .media-gallery {
      background: #fff;
      border: 1px solid #d6d6d6;
      margin-top: 8px;
    }
    .media-gallery-topbar {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      padding: 10px 14px;
      background: #f5f5f5;
      border-bottom: 1px solid #d6d6d6;
    }
    .media-gallery-topbar-actions {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 12px 16px;
    }
    .media-gallery-link {
      background: none;
      border: none;
      padding: 0;
      color: #1979c3;
      font-size: 0.875rem;
      cursor: pointer;
      text-decoration: none;
    }
    .media-gallery-link:hover:not(:disabled) { text-decoration: underline; }
    .media-gallery-link:disabled { color: #999; cursor: default; text-decoration: none; }
    .media-gallery-btn {
      padding: 6px 14px;
      font-size: 0.875rem;
      background: #e3e3e3;
      border: 1px solid #adadad;
      color: #303030;
      cursor: pointer;
      border-radius: 2px;
    }
    .media-gallery-btn:hover { background: #d8d8d8; }
    .media-gallery-body {
      display: flex;
      min-height: 420px;
    }
    .media-gallery-tree {
      width: 240px;
      flex-shrink: 0;
      border-right: 1px solid #d6d6d6;
      padding: 10px 0 12px;
      background: #fafafa;
      overflow: auto;
    }
    .media-gallery-tree-controls {
      padding: 0 12px 8px;
      font-size: 0.8125rem;
    }
    .media-gallery-tree-sep { color: #999; margin: 0 4px; }
    .media-gallery-tree-root { padding: 0 4px; font-size: 0.875rem; }
    .media-folder-node { user-select: none; }
    .media-folder-row {
      display: flex;
      align-items: center;
      gap: 2px;
      padding: 4px 8px 4px 4px;
      cursor: pointer;
      border-radius: 2px;
      white-space: nowrap;
    }
    .media-folder-row:hover { background: #eee; }
    .media-folder-row.selected { background: #e8f4fc; }
    .media-folder-toggle {
      width: 16px;
      height: 16px;
      border: none;
      background: transparent;
      padding: 0;
      cursor: pointer;
      color: #666;
      font-size: 0.65rem;
      line-height: 1;
      flex-shrink: 0;
    }
    .media-folder-toggle.placeholder { visibility: hidden; }
    .media-folder-icon { width: 16px; text-align: center; flex-shrink: 0; }
    .media-folder-label { overflow: hidden; text-overflow: ellipsis; }
    .media-folder-children { margin-left: 14px; }
    .media-folder-children.collapsed { display: none; }
    .media-gallery-main {
      flex: 1;
      padding: 14px 16px 16px;
      min-width: 0;
    }
    .media-gallery-upload-row {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 12px;
      flex-wrap: wrap;
    }
    .media-gallery-upload-label { font-size: 0.875rem; color: #303030; }
    .media-gallery-upload-status { font-size: 0.8125rem; color: #666; }
    .media-gallery-message { margin-bottom: 8px; font-size: 0.875rem; min-height: 1.2em; }
    .media-gallery-message.error { color: #b30000; }
    .media-gallery-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      align-items: flex-start;
      min-height: 120px;
    }
    .media-gallery-card {
      width: 140px;
      border: 1px solid #c8c8c8;
      background: #fff;
      cursor: pointer;
      flex-shrink: 0;
    }
    .media-gallery-card.selected { border-color: #007bdb; box-shadow: 0 0 0 1px #007bdb; }
    .media-gallery-card-preview {
      height: 120px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: #f7f7f7;
      border-bottom: 1px solid #e0e0e0;
      overflow: hidden;
    }
    .media-gallery-card-preview img {
      max-width: 100%;
      max-height: 100%;
      object-fit: contain;
    }
    .media-gallery-card-placeholder {
      font-size: 0.7rem;
      color: #888;
      text-align: center;
      padding: 8px;
      line-height: 1.3;
    }
    .media-gallery-card-meta {
      padding: 8px 8px 10px;
      font-size: 0.75rem;
      color: #303030;
      line-height: 1.35;
    }
    .media-gallery-card-dims { color: #666; margin-bottom: 2px; }
    .media-gallery-card-name {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .media-gallery-content { min-height: 120px; }
    .media-gallery-footer {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: space-between;
      gap: 12px 20px;
      margin-top: 14px;
      padding-top: 12px;
      border-top: 1px solid #e0e0e0;
      font-size: 0.8125rem;
    }
    .media-gallery-footer-left,
    .media-gallery-footer-right {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 12px 16px;
    }
    .media-gallery-footer-label {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      color: #303030;
      font-size: 0.8125rem;
    }
    .media-gallery-footer-select {
      padding: 4px 8px;
      font-size: 0.8125rem;
      border: 1px solid #adadad;
      background: #fff;
      border-radius: 2px;
    }
    .media-gallery-total-found { color: #666; }
    .media-gallery-pager {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }
    .media-gallery-pager .grid-pager-arrow {
      padding: 4px 8px;
      border: 1px solid #adadad;
      background: #f5f5f5;
      cursor: pointer;
      border-radius: 2px;
      line-height: 1;
    }
    .media-gallery-pager .grid-pager-arrow:disabled {
      opacity: 0.45;
      cursor: default;
    }
    .media-gallery-pager-page-wrap {
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .media-gallery-pager .grid-pager-page-input {
      width: 48px;
      padding: 4px 6px;
      text-align: center;
      border: 1px solid #adadad;
      font-size: 0.8125rem;
    }
    .media-gallery-pager-of {
      color: #666;
      white-space: nowrap;
    }
    .media-gallery-file-table {
      width: 100%;
      border-collapse: collapse;
      font-size: 0.875rem;
    }
    .media-gallery-file-table th {
      text-align: left;
      padding: 8px 10px;
      border-bottom: 1px solid #d6d6d6;
      font-weight: 600;
      color: #303030;
      background: #f5f5f5;
    }
    .media-gallery-file-table td {
      padding: 8px 10px;
      border-bottom: 1px solid #eee;
      vertical-align: middle;
    }
    .media-gallery-file-row { cursor: pointer; }
    .media-gallery-file-row:hover { background: #f7f7f7; }
    .media-gallery-file-row.selected { background: #e8f4fc; }
    .media-gallery-file-name {
      word-break: break-all;
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
      font-size: 0.8125rem;
    }
    .media-gallery-file-content-cell { min-width: 280px; max-width: 520px; vertical-align: top !important; }
    .media-gallery-file-content-wrap {
      display: flex;
      align-items: flex-start;
      gap: 8px;
    }
    .media-gallery-file-content-textarea {
      flex: 1;
      min-width: 0;
      min-height: 72px;
      max-height: 160px;
      resize: vertical;
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
      font-size: 0.75rem;
      line-height: 1.4;
      padding: 6px 8px;
      border: 1px solid #d1d1d1;
      border-radius: 4px;
      background: #fafafa;
      color: #303030;
    }
    .media-gallery-file-content-copy {
      flex-shrink: 0;
      width: 32px;
      height: 32px;
      padding: 0;
      border: 1px solid #d1d1d1;
      border-radius: 4px;
      background: #fff;
      color: #505050;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .media-gallery-file-content-copy:hover { background: #f5f5f5; border-color: #adadad; color: #eb5202; }
    .media-gallery-file-content-copy:disabled { opacity: 0.5; cursor: not-allowed; }
    .media-gallery-file-content-placeholder { color: #888; font-size: 0.8125rem; font-style: italic; }
    .media-gallery-content--content .media-gallery-file-table td { vertical-align: top; }
    .media-gallery-empty {
      color: #666;
      font-size: 0.875rem;
      padding: 24px 0;
    }
    .btn-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 12px; }
    .detail-edit-toolbar {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      flex-wrap: wrap;
      gap: 10px 16px;
      margin-bottom: 12px;
    }
    .detail-edit-toolbar-lead {
      display: inline-flex;
      align-items: center;
      gap: 12px 16px;
      flex: 0 1 auto;
      min-width: 0;
      max-width: 100%;
    }
    .detail-edit-toolbar-lead > .btn-refresh {
      flex-shrink: 0;
      margin: 0;
      height: 34px;
      box-sizing: border-box;
      padding: 0 14px;
      display: inline-flex;
      align-items: center;
      line-height: 1;
    }
    #main-content .detail-edit-toolbar-lead h2.exercise-edit-heading__title {
      margin: 0;
      padding: 0;
      height: 34px;
      box-sizing: border-box;
      font-size: 1.125rem;
      font-weight: 600;
      line-height: 1;
      flex: 0 1 auto;
      min-width: 0;
      color: #1a1a1a;
      display: inline-flex;
      align-items: center;
    }
    .exercise-edit-heading-meta {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px;
      margin: 0 0 12px 0;
      min-height: 36px;
    }
    .exercise-edit-heading-meta.hidden { display: none !important; }
    .exercise-edit-heading-meta__inner {
      display: inline-flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px;
    }
    .exercise-edit-heading-meta .exercise-edit-heading__prefix {
      font-size: 0.9375rem;
      font-weight: 400;
      color: #64748b;
    }
    .exercise-edit-heading-meta .exercise-edit-heading__id-label {
      font-size: 0.875rem;
      color: #94a3b8;
      margin-left: 2px;
    }
    .exercise-edit-heading-meta .exercise-edit-heading__id-value {
      font-size: 1.125rem;
      font-weight: 700;
      color: #1a1a1a;
    }
    .grid-action-submenu__buttons {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      gap: 8px;
      min-width: 200px;
    }
    .grid-action-submenu__btn { width: 100%; text-align: left; }
    .detail-edit-toolbar .detail-edit-toolbar-spacer { flex: 1 1 auto; min-width: 0; }
    .detail-edit-toolbar .detail-edit-toolbar-save { margin-left: 0; }
    .detail-edit-toolbar .detail-edit-toolbar-save.hidden { display: none !important; }
    .detail-edit-toolbar .detail-edit-toolbar-actions { margin-left: auto; display: inline-flex; gap: 8px; align-items: center; }
    .confirm-action-modal-inner { display: flex; gap: 16px; align-items: flex-start; }
    .confirm-action-modal-icon { flex-shrink: 0; color: #eb5202; margin-top: 2px; line-height: 0; }
    .confirm-action-modal-text { flex: 1; min-width: 0; }
    .grid-toolbar {
      display: flex; flex-direction: column; align-items: stretch; gap: 10px;
      margin-bottom: 12px; max-width: none; width: 100%;
    }
    .grid-toolbar.wide { max-width: none; width: 100%; }
    .grid-toolbar-primary {
      display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; align-items: center;
    }
    .grid-toolbar-primary:empty { display: none; }
    .grid-toolbar-controls {
      display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px;
    }
    .grid-toolbar-left, .grid-toolbar-right { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
    .cell-visual-map-links { display: inline-flex; flex-direction: row; gap: 4px; align-items: center; white-space: nowrap; }
    .cell-visual-map-links .btn-icon,
    .cell-visual-map-links .cell-visual-map-btn { padding: 2px; line-height: 0; opacity: 1; cursor: pointer; pointer-events: auto; }
    .cell-visual-map-links .btn-icon:disabled,
    .cell-visual-map-links .cell-visual-map-btn:disabled { opacity: 1; cursor: pointer; pointer-events: auto; }
    .grid-toolbar .btn-primary, .grid-toolbar .btn-refresh { align-self: center; }
    .grid-toolbar-actions-label { font-size: 0.8125rem; color: #444; display: flex; align-items: center; gap: 8px; }
    .grid-actions-select {
      padding: 7px 32px 7px 12px; font-size: 0.875rem; font-family: inherit;
      border: 1px solid #c5c5c5; border-radius: 6px; min-width: 9rem;
      background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
      color: #303030; cursor: pointer; appearance: none;
    }
    .grid-actions-select:hover { border-color: #9ca3af; background-color: #fafafa; }
    .grid-actions-select:focus { outline: none; border-color: #eb5202; box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.2); }
    .grid-toolbar-actions-menu-wrap { position: relative; display: inline-block; flex-shrink: 0; }
    .grid-toolbar-actions-btn {
      display: inline-flex; align-items: center; justify-content: center; gap: 6px;
      min-width: 8.5rem; padding: 7px 12px; font-size: 0.875rem; font-family: inherit;
      border: 1px solid #c5c5c5; border-radius: 6px; background: #fff; cursor: pointer; color: #303030;
    }
    .grid-toolbar-actions-btn:hover { background: #f3f4f6; border-color: #9ca3af; }
    .grid-toolbar-actions-btn-chevron { flex-shrink: 0; opacity: 0.7; }
    .grid-toolbar-actions-menu {
      position: absolute; left: 0; top: 100%; margin-top: 4px; z-index: 95;
      min-width: 12rem; list-style: none; margin: 0; padding: 4px 0;
      background: #fff; border: 1px solid #e3e3e3; border-radius: 6px;
      box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
    }
    .grid-toolbar-actions-menu.hidden { display: none !important; }
    .grid-toolbar-actions-menu-row { position: relative; margin: 0; padding: 0; list-style: none; }
    .grid-toolbar-actions-menu-item {
      display: flex; align-items: center; justify-content: space-between; gap: 12px;
      width: 100%; box-sizing: border-box; text-align: left; border: none; background: none;
      margin: 0; padding: 8px 14px; font-size: 0.875rem; font-family: inherit; cursor: pointer;
      font-weight: 500; color: #303030;
    }
    .grid-toolbar-actions-menu-row:hover > .grid-toolbar-actions-menu-item,
    .grid-toolbar-actions-menu-row:focus-within > .grid-toolbar-actions-menu-item {
      background: #f3f4f6;
    }
    .grid-toolbar-actions-flyout-chevron { font-size: 1rem; line-height: 1; color: #9ca3af; font-weight: 400; }
    .grid-toolbar-actions-flyout-bridge {
      position: absolute; left: 100%; top: 0; width: 10px; height: 100%;
      background: transparent; pointer-events: auto; z-index: 96;
    }
    .grid-toolbar-actions-flyout {
      position: absolute; left: calc(100% + 2px); top: -4px; z-index: 97;
      min-width: 10.5rem; list-style: none; margin: 0; padding: 4px 0;
      background: #fff; border: 1px solid #e3e3e3; border-radius: 6px;
      box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
      display: none;
    }
    .grid-toolbar-actions-menu-row.has-flyout:hover > .grid-toolbar-actions-flyout,
    .grid-toolbar-actions-menu-row.has-flyout:focus-within > .grid-toolbar-actions-flyout {
      display: block;
    }
    .grid-toolbar-actions-flyout-item {
      display: block; width: 100%; box-sizing: border-box; text-align: left;
      border: none; background: none; margin: 0; padding: 8px 14px;
      font-size: 0.875rem; font-family: inherit; cursor: pointer; font-weight: 400; color: #303030;
    }
    .grid-toolbar-actions-flyout-item:hover { background: #f3f4f6; }
    .detail-import-export-wrap { position: relative; display: inline-block; }
    .detail-import-export-wrap .detail-import-export-flyout {
      position: absolute; right: 0; top: 100%; margin-top: 4px; left: auto;
      display: none;
    }
    .detail-import-export-wrap.is-open .detail-import-export-flyout,
    .detail-import-export-wrap:hover .detail-import-export-flyout {
      display: block;
    }
    .grid-total-found { font-size: 0.8125rem; color: #666; }
    .grid-selection-summary { font-size: 0.8125rem; color: #444; }
    .btn-icon {
      display: inline-flex; align-items: center; justify-content: center;
      width: 30px; height: 30px; padding: 0; flex-shrink: 0;
      cursor: pointer; background: #fff; border: 1px solid #adadad; border-radius: 2px; color: #303030;
    }
    .btn-icon:hover { border-color: #666; }
    .btn-filters {
      display: inline-flex; align-items: center; gap: 6px; flex-shrink: 0;
      padding: 6px 10px; font-size: 0.8125rem; cursor: pointer;
      background: #fff; border: 1px solid #adadad; border-radius: 2px; color: #303030;
    }
    .btn-filters:hover { border-color: #666; }
    .btn-filters-icon { display: block; flex-shrink: 0; }
    .grid-toolbar label.per-page { font-size: 0.8125rem; color: #444; display: flex; align-items: center; gap: 6px; }
    .grid-toolbar select.per-page-select { padding: 6px 10px; font-size: 0.875rem; border: 1px solid #adadad; border-radius: 2px; }
    .grid-search-panel {
      border: 1px solid #e3e3e3; background: #fafafa; padding: 12px 14px; margin-bottom: 12px; border-radius: 2px; max-width: none; width: 100%;
    }
    .grid-search-panel.wide { max-width: none; width: 100%; }
    .grid-search-panel .search-row { display: flex; flex-wrap: wrap; gap: 10px 16px; align-items: flex-end; }
    .grid-search-panel .search-submit { flex: 0 0 auto; align-self: flex-end; margin-bottom: 1px; }
    .grid-search-panel label { font-size: 0.8125rem; color: #555; display: flex; flex-direction: column; gap: 4px; }
    .grid-search-panel input, .grid-search-panel select { padding: 6px 10px; min-width: 160px; border: 1px solid #adadad; border-radius: 2px; font-size: 0.875rem; }
    .grid-toolbar-pager { font-size: 0.8125rem; color: #444; display: flex; align-items: center; flex-wrap: wrap; }
    .grid-toolbar-paging {
      display: inline-flex; align-items: center; gap: 6px; flex-wrap: nowrap; flex-shrink: 0;
    }
    .grid-toolbar-paging label.per-page { margin: 0; white-space: nowrap; flex-shrink: 0; }
    .grid-toolbar-paging .grid-toolbar-pager { flex-wrap: nowrap; flex-shrink: 0; }
    .grid-toolbar-paging .grid-pagination-inner { flex-wrap: nowrap; }
    #view-customer-settings .customer-tab-pane .grid-toolbar-controls {
      flex-wrap: wrap; align-items: center; gap: 8px 12px;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-left {
      flex: 1 1 auto; min-width: 0;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-right {
      flex-wrap: wrap; justify-content: flex-end; align-items: center; row-gap: 8px;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging label.per-page {
      display: inline-flex; align-items: center; gap: 6px; font-size: 0.8125rem; line-height: 1; height: 30px;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging select.per-page-select {
      height: 30px; padding: 0 8px; font-size: 0.8125rem; line-height: 1; box-sizing: border-box;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging .grid-toolbar-pager,
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging .grid-pagination-inner {
      height: 30px; align-items: center; gap: 6px;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging .grid-pager-page-input {
      height: 30px; width: 2.75rem; min-width: 2.5rem; padding: 0 4px; font-size: 0.8125rem; line-height: 1; box-sizing: border-box;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-paging .grid-pager-of {
      font-size: 0.8125rem; line-height: 1; height: 30px;
    }
    #view-customer-settings .customer-tab-pane .grid-toolbar-right > .btn-primary {
      height: 30px; padding: 0 12px; font-size: 0.8125rem; line-height: 1; box-sizing: border-box;
      display: inline-flex; align-items: center; flex-shrink: 0;
    }
    .grid-pagination-inner { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
    .grid-pager-arrow {
      display: inline-flex; align-items: center; justify-content: center;
      width: 30px; height: 30px; padding: 0; margin: 0;
      cursor: pointer; background: #fff; border: 1px solid #adadad; border-radius: 2px;
      color: #303030; flex-shrink: 0;
    }
    .grid-pager-arrow:hover:not(:disabled) { border-color: #666; }
    .grid-pager-arrow:disabled { opacity: 0.42; cursor: default; }
    .grid-pager-page-input {
      width: 3rem; min-width: 2.5rem; padding: 5px 4px; text-align: center; font-size: 0.8125rem;
      border: 1px solid #adadad; border-radius: 2px; box-sizing: border-box;
      -moz-appearance: textfield;
    }
    .grid-pager-page-input::-webkit-outer-spin-button,
    .grid-pager-page-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
    .grid-pager-total,
    .grid-pager-of {
      font-size: 0.8125rem;
      color: #666;
      white-space: nowrap;
      line-height: 1;
      display: inline-flex;
      align-items: center;
    }
    .customer-detail-columns { display: flex; flex-wrap: wrap; gap: 24px 40px; align-items: flex-start; margin-bottom: 8px; }
    .customer-detail-columns .customer-form-section { flex: 1 1 280px; max-width: 520px; margin-bottom: 0; min-width: 240px; }
    .sales-detail-table { table-layout: fixed; width: 100%; }
    .sales-transaction-detail-layout .sales-transaction-detail-section { max-width: 520px; }
    .sales-transaction-detail-layout .sales-invoice-detail-full-section {
      max-width: none;
      width: 100%;
    }
    .sales-transaction-detail-layout .sales-invoice-detail-full-section .data {
      width: 100%;
    }
    .sales-transaction-detail-layout .sales-record-detail-side {
      flex: 1 1 280px;
      max-width: 520px;
      min-width: 240px;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
    .sales-transaction-detail-layout .sales-record-detail-side > .customer-form-section {
      margin-bottom: 0;
    }
    .sales-transaction-detail-layout .sales-record-detail-side .sales-transaction-payment-section .form-section-title {
      margin-top: 0;
    }
    .sales-transaction-detail-layout .sales-detail-table th {
      width: 9.5rem;
      min-width: 9.5rem;
      max-width: 9.5rem;
      font-weight: 600;
      white-space: nowrap;
      vertical-align: top;
      padding-right: 12px;
    }
    .sales-transaction-detail-layout .sales-detail-table td {
      vertical-align: top;
      word-break: break-word;
    }
    .sales-transaction-detail-layout .sales-transaction-payment-section { margin-top: 0; }
    .sales-transaction-detail-layout .sales-transaction-comments-section { margin-bottom: 0; }
    .sales-transaction-detail-layout .sales-transaction-comments-block { margin-top: 0; }
    .sales-transaction-detail-layout .sales-detail-table--comments-label { margin-bottom: 0; }
    .sales-transaction-detail-layout .sales-detail-table--comments-label td { padding-top: 0; }
    .sales-comments-list { display: flex; flex-direction: column; gap: 10px; margin: 0 0 0.75rem; width: 100%; }
    .sales-comment-entry { border: 1px solid var(--border-subtle, #e5e7eb); border-radius: 8px; padding: 10px 12px; background: var(--surface-muted, #f9fafb); width: 100%; box-sizing: border-box; }
    .sales-comment-entry__meta { font-size: 0.8125rem; color: var(--text-muted, #6b7280); margin-bottom: 4px; }
    .sales-comment-entry__text { white-space: pre-wrap; word-break: break-word; }
    .sales-comment-input { width: 100%; min-height: 72px; box-sizing: border-box; }
    .sales-comment-actions { margin-top: 0.5rem; }
    .sales-comment-error { margin-top: 0.5rem; }
    .sales-comments-empty { margin: 0 0 0.5rem; }
    .admin-captcha-detail-layout {
      display: flex;
      flex-direction: column;
      gap: 24px;
      align-items: stretch;
    }
    .admin-captcha-detail-layout > .customer-form-section:first-child {
      flex: 0 1 auto;
      max-width: 520px;
      width: 100%;
    }
    .admin-captcha-detail-layout > .customer-form-section--options {
      flex: 1 1 100%;
      max-width: none;
      min-width: 0;
      width: 100%;
    }
    #admin-captcha-options-table {
      width: 100%;
      table-layout: auto;
    }
    #admin-captcha-options-table th,
    #admin-captcha-options-table td {
      vertical-align: middle;
    }
    #admin-captcha-options-table .config-visuals-inline-input {
      width: 100%;
      min-width: 0;
    }
    #admin-captcha-options-table td:nth-child(1) { min-width: 180px; }
    #admin-captcha-options-table td:nth-child(2) { min-width: 140px; }
    #admin-captcha-options-table td:nth-child(3) { min-width: 160px; }
    #admin-captcha-options-table td:nth-child(4),
    #admin-captcha-options-table td:nth-child(5) {
      width: 72px;
      text-align: center;
    }
    #admin-captcha-options-table td:nth-child(6) { width: 88px; }
    #admin-captcha-options-table td:nth-child(7) { width: 96px; white-space: nowrap; }
    .customer-form-section { margin-bottom: 24px; max-width: 560px; }
    .customer-profile-photo-wrap { margin-bottom: 12px; }
    .customer-profile-photo {
      width: 56px;
      height: 56px;
      border-radius: 999px;
      object-fit: cover;
      border: 1px solid #e4e7ec;
      background: #f6f7f9;
      display: block;
    }
    .form-section-title { display: flex; align-items: center; gap: 10px; margin: 0 0 12px; font-size: 1rem; font-weight: 600; color: #303030; }
    .form-section-icon { display: inline-flex; color: #eb5202; flex-shrink: 0; }
    .form-section-icon svg { display: block; }
    .customer-meta-bar { display: flex; flex-wrap: wrap; gap: 10px 12px; align-items: center; }
    .customer-meta-bar .meta-chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; background: #f6f7f9; border: 1px solid #e4e7ec; border-radius: 8px; font-size: 0.8125rem; color: #444; line-height: 1.35; }
    .customer-meta-bar .meta-chip svg { flex-shrink: 0; color: #eb5202; opacity: 0.92; }
    .customer-meta-bar .meta-chip strong { font-weight: 600; color: #303030; margin-right: 4px; }
    .customer-form-section label { display: block; font-size: 0.8125rem; color: #555; margin-bottom: 4px; }
    .customer-form-section input:not([type="checkbox"]):not([type="radio"]), .customer-form-section select, .customer-form-section textarea {
      width: 100%; max-width: 400px; padding: 8px 10px; margin-bottom: 12px; border: 1px solid #adadad; border-radius: 2px; font-size: 0.875rem; box-sizing: border-box;
    }
    .customer-form-section textarea { min-height: 64px; resize: vertical; max-width: 100%; }
    .reports-revenue-filters-section { max-width: none; width: 100%; }
    .reports-revenue-filters-row {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px 16px;
      align-items: end;
      width: 100%;
    }
    .reports-revenue-mode-filters:not(.hidden) { display: contents; }
    .reports-revenue-mode-filters.hidden { display: none; }
    .reports-revenue-filter-field label {
      display: block;
      font-size: 0.8125rem;
      color: #555;
      margin-bottom: 4px;
    }
    .reports-revenue-filter-field input,
    .reports-revenue-filter-field select {
      width: 100%;
      max-width: none;
      padding: 8px 10px;
      margin-bottom: 0;
      border: 1px solid #adadad;
      border-radius: 2px;
      font-size: 0.875rem;
      box-sizing: border-box;
    }
    .customer-goals-fieldset { border: 0; margin: 0 0 16px; padding: 0; }
    .customer-goals-fieldset legend {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 1rem;
      font-weight: 600;
      color: #303030;
      margin-bottom: 8px;
      padding: 0;
    }
    .customer-goals-step {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      margin-right: 8px;
      border-radius: 999px;
      background: #fff1eb;
      color: #eb5202;
      font-size: 11px;
      font-weight: 800;
      flex-shrink: 0;
    }
    .customer-goals-section { margin-top: 0; }
    .customer-goals-section + .customer-goals-section { margin-top: 20px; }
    .customer-goals-section-title {
      display: flex;
      align-items: center;
      gap: 10px;
      margin: 0 0 12px;
      font-size: 1rem;
      font-weight: 600;
      color: #303030;
    }
    .customer-detail-columns .customer-goals-benefits {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
      gap: 8px 12px;
      margin-bottom: 12px;
      max-width: none;
    }
    .customer-goals-benefits__item {
      display: flex;
      align-items: flex-start;
      gap: 8px;
      margin: 0;
      font-size: 0.8125rem;
      color: #303030;
      cursor: pointer;
    }
    .customer-goals-benefits__input {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      border: 0;
    }
    .customer-goals-benefits__check {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 18px;
      height: 18px;
      margin-top: 1px;
      border: 1.5px solid #d1d5db;
      border-radius: 5px;
      color: #fff;
      flex-shrink: 0;
    }
    .customer-goals-benefits__item:has(input:checked) .customer-goals-benefits__check {
      border-color: #eb5202;
      background: #eb5202;
    }
    .customer-workout-days { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; max-width: 480px; }
    .customer-workout-days label { display: inline-flex; align-items: center; gap: 6px; margin: 0; padding: 6px 10px; border: 1px solid #d1d1d1; border-radius: 999px; font-size: 0.8125rem; cursor: pointer; background: #fff; }
    .customer-workout-days input { width: auto; max-width: none; margin: 0; }
    .customer-pref-toggle-list { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; max-width: 520px; }
    .customer-pref-toggle {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      margin: 0 !important;
      padding: 12px 14px;
      border: 1px solid #e4e7ec;
      border-radius: 10px;
      background: #fff;
      cursor: pointer;
      font-size: inherit !important;
      color: inherit !important;
      transition: border-color 0.15s ease, background 0.15s ease;
    }
    .customer-pref-toggle:hover { border-color: #d1d5db; background: #fafbfc; }
    .customer-pref-toggle:has(input:checked) { border-color: #f5c4a8; background: #fff8f4; }
    .customer-pref-toggle__copy { flex: 1; min-width: 0; }
    .customer-pref-toggle__copy strong { display: block; margin-bottom: 2px; font-size: 0.875rem; font-weight: 600; color: #303030; }
    .customer-pref-toggle__copy small { display: block; font-size: 0.75rem; line-height: 1.45; color: #666; font-weight: 400; }
    .customer-pref-toggle input[type="checkbox"] {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }
    .customer-pref-toggle__switch {
      position: relative;
      flex-shrink: 0;
      width: 44px;
      height: 24px;
      border-radius: 999px;
      background: #d1d5db;
      transition: background 0.2s ease;
    }
    .customer-pref-toggle:has(input:checked) .customer-pref-toggle__switch { background: #eb5202; }
    .customer-pref-toggle:has(input:focus-visible) .customer-pref-toggle__switch { outline: 2px solid #eb5202; outline-offset: 2px; }
    .customer-pref-toggle:has(input:disabled) { opacity: 0.65; cursor: not-allowed; }
    .customer-pref-toggle__knob {
      position: absolute;
      top: 2px;
      left: 2px;
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: #fff;
      box-shadow: 0 1px 3px rgba(17, 24, 39, 0.16);
      transition: transform 0.2s ease;
    }
    .customer-pref-toggle:has(input:checked) .customer-pref-toggle__knob { transform: translateX(20px); }
    .customer-privacy-row {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 16px;
      align-items: start;
      margin-top: 4px;
    }
    .customer-privacy-field label {
      display: block;
      margin-bottom: 0;
    }
    .customer-privacy-field select {
      width: 100%;
      max-width: none;
    }
    .customer-privacy-toggle {
      align-self: stretch;
      height: 100%;
      min-height: 72px;
    }
    @media (max-width: 1100px) {
      .customer-privacy-row { grid-template-columns: 1fr; }
    }
    .customer-field-hint {
      margin: -2px 0 6px;
      font-size: 0.75rem;
      line-height: 1.45;
      color: #666;
      font-weight: 400;
    }
    .bv-field-stack, .bv-collapsible-stack { display: flex; flex-direction: column; gap: 10px; }
    .bv-static-section {
      border: 1px solid #e5e7eb;
      border-radius: 8px;
      padding: 8px 12px 12px;
      background: #fafafa;
    }
    .bv-static-section-title { font-weight: 600; margin-bottom: 6px; }
    .bv-static-section-label { display: block; margin-bottom: 4px; color: #666; font-size: 0.8125rem; }
    .bv-static-section input { width: 100%; max-width: 100%; box-sizing: border-box; margin-bottom: 0; }
    .bv-collapsible-section {
      border: 1px solid #e5e7eb;
      border-radius: 8px;
      background: #fafafa;
      overflow: hidden;
    }
    .bv-collapsible-section > summary {
      list-style: none;
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 12px 10px 14px;
      box-sizing: border-box;
    }
    .bv-collapsible-section > summary::-webkit-details-marker { display: none; }
    .bv-collapsible-section > summary::before {
      content: "";
      width: 0;
      height: 0;
      border-left: 5px solid #555;
      border-top: 4px solid transparent;
      border-bottom: 4px solid transparent;
      flex-shrink: 0;
      transform: rotate(0deg);
      transition: transform 0.12s ease;
    }
    .bv-collapsible-section[open] > summary::before { transform: rotate(90deg); }
    .bv-collapsible-summary {
      font-weight: 600;
      padding: 0;
      cursor: pointer;
      user-select: none;
      flex: 1;
      min-width: 0;
    }
    .bv-collapsible-section[open] > summary { border-bottom: 1px solid #e5e7eb; }
    .bv-collapsible-body { padding: 8px 12px 12px; }
    .bv-collapsible-body label { display: block; margin-bottom: 4px; color: #666; font-size: 0.8125rem; }
    .bv-collapsible-body input { width: 100%; max-width: 100%; box-sizing: border-box; margin-bottom: 10px; }
    .bv-collapsible-body input:last-child { margin-bottom: 0; }

    /* Body-visual polygon tree — override .customer-form-section defaults */
    .bv-tree-root { display: flex; flex-direction: column; gap: 12px; }
    .bv-tree-root label { display: inline !important; margin-bottom: 0 !important; }
    .bv-tree-root input[type="checkbox"] {
      width: auto !important; max-width: none !important; padding: 0 !important;
      margin: 0 !important; display: inline-block !important;
    }
    .bv-tree-side { border: 1px solid #d1d5db; border-radius: 8px; overflow: hidden; }
    .bv-tree-side > summary { list-style: none; }
    .bv-tree-side > summary::-webkit-details-marker { display: none; }
    .bv-tree-side-summary {
      cursor: pointer; padding: 10px 14px; font-weight: 700; font-size: 0.9375rem;
      background: #f3f4f6; user-select: none; display: flex; align-items: center; gap: 8px;
    }
    .bv-tree-side-summary::before {
      content: "▸"; display: inline-block; font-size: 1.1rem; transition: transform 0.12s ease;
    }
    .bv-tree-side[open] > summary .bv-tree-side-summary::before { transform: rotate(90deg); }
    .bv-tree-side-summary small { font-weight: 400; color: #888; }
    .bv-tree-side[open] > summary { border-bottom: 1px solid #d1d5db; }
    .bv-tree-side-body { padding: 6px 0; }

    .bv-tree-group { border-bottom: 1px solid #e5e7eb; }
    .bv-tree-group:last-child { border-bottom: none; }
    .bv-tree-group > summary { list-style: none; }
    .bv-tree-group > summary::-webkit-details-marker { display: none; }
    .bv-tree-group-summary {
      cursor: pointer; padding: 8px 14px 8px 20px; font-size: 0.875rem;
      background: #fafafa; user-select: none; display: flex; align-items: center; gap: 8px;
    }
    .bv-tree-group-summary::before {
      content: "▸"; display: inline-block; font-size: 1rem; color: #666; transition: transform 0.12s ease; flex-shrink: 0;
    }
    .bv-tree-group[open] > summary .bv-tree-group-summary::before { transform: rotate(90deg); }
    .bv-tree-group-label {
      display: flex !important; align-items: center; gap: 6px; cursor: pointer; font-weight: 600;
    }
    .bv-tree-group-label small { font-weight: 400; color: #999; }
    .bv-tree-group[open] > summary { border-bottom: 1px solid #eee; }
    .bv-tree-group-body { padding: 6px 14px 10px 46px; }

    .bv-tree-muscle-row { display: flex; flex-direction: column; gap: 3px; margin-bottom: 8px; }
    .bv-tree-muscle-row:last-child { margin-bottom: 0; }
    .bv-tree-muscle-check {
      display: flex !important; align-items: center; gap: 6px; font-size: 0.8125rem; cursor: pointer; line-height: 1.4;
    }
    .bv-tree-muscle-check strong { color: #111; }
    .bv-tree-muscle-check small { color: #888; }
    .bv-tree-pts-input {
      max-width: 100% !important; box-sizing: border-box; font-size: 0.8125rem;
      padding: 4px 8px !important; border: 1px solid #d1d5db; border-radius: 4px; font-family: monospace;
      margin-left: 20px; width: calc(100% - 20px) !important; margin-bottom: 0 !important;
    }
    .bv-tree-pts-input:disabled { background: #f3f4f6; color: #aaa; border-color: #e5e7eb; }

    /* Coordinate detail sections in muscle/group edit */
    .bv-coords-detail { border: 1px solid #e5e7eb; border-radius: 6px; margin-bottom: 6px; overflow: hidden; }
    .bv-coords-detail > summary {
      cursor: pointer; padding: 6px 12px; font-size: 0.8125rem; font-weight: 600;
      background: #fafafa; user-select: none; list-style: none;
    }
    .bv-coords-detail > summary::-webkit-details-marker { display: none; }
    .bv-coords-detail > summary::before { content: "▸ "; font-size: 0.9rem; }
    .bv-coords-detail[open] > summary::before { content: "▾ "; }
    .bv-coords-detail[open] > summary { border-bottom: 1px solid #e5e7eb; }
    .muscle-pts-textarea {
      width: 100%; box-sizing: border-box; font-family: monospace; font-size: 0.8125rem;
      padding: 6px 10px; border: none; border-radius: 0; resize: vertical; margin: 0;
    }

    .customer-readonly-meta { margin-bottom: 18px; line-height: 1.5; }
    .support-ticket-detail-columns .support-ticket-conversation { flex: 1 1 420px; max-width: none; min-width: 320px; }
    .support-ticket-detail-columns .customer-form-section:not(.support-ticket-conversation) { flex: 0 1 320px; max-width: 360px; }
    .support-ticket-chat { display: flex; flex-direction: column; border: 1px solid var(--border, #ececec); border-radius: 10px; min-height: 480px; background: #fff; }
    .support-ticket-chat__messages { flex: 1; min-height: 0; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 16px; }
    .support-ticket-chat__empty { margin: 0; color: #6b7280; font-size: 14px; }
    .support-ticket-chat__load-more { align-self: center; margin: 0 auto 4px; padding: 8px 14px; border: 1px solid var(--border, #ececec); border-radius: 999px; background: #fff; color: #6b7280; font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit; }
    .support-ticket-chat__load-more:hover { border-color: #fdba74; color: #eb5202; }
    .support-ticket-chat__bubble-wrap { display: flex; flex-direction: column; max-width: 78%; gap: 6px; }
    .support-ticket-chat__bubble-wrap--customer { align-self: flex-start; align-items: flex-start; }
    .support-ticket-chat__bubble-wrap--support { align-self: flex-end; align-items: flex-end; }
    .support-ticket-chat__bubble { border-radius: 12px; padding: 12px 14px; font-size: 14px; line-height: 1.55; }
    .support-ticket-chat__bubble--customer { background: #f3f4f6; color: #1f2937; }
    .support-ticket-chat__bubble--support { background: #ff6a00; color: #fff; }
    .support-ticket-chat__bubble-time { font-size: 12px; color: #9ca3af; }
    .support-ticket-chat__bubble-wrap--support .support-ticket-chat__bubble-time { color: #fb923c; }
    .support-ticket-reply { border-top: 1px solid var(--border, #ececec); padding: 14px 18px 18px; display: flex; flex-direction: column; gap: 10px; }
    .support-ticket-reply textarea { width: 100%; min-height: 96px; border: 1px solid var(--border, #ececec); border-radius: 10px; padding: 10px 12px; font-family: inherit; font-size: 14px; line-height: 1.5; resize: vertical; }
    .support-ticket-reply .btn-primary { align-self: flex-end; }
    .modal-field-hint { margin: 8px 0 18px; font-size: 0.75rem; color: #666; line-height: 1.45; display: block; }
    .modal-body input.admin-user-edit-pass-input { margin-bottom: 2px; }
    .btn-primary { padding: 8px 14px; cursor: pointer; background: #eb5202; color: #fff; border: 1px solid #eb5202; border-radius: 2px; font-size: 0.875rem; font-weight: 600; }
    .btn-primary:hover { background: #d24b02; }
    .btn-small { padding: 4px 10px; font-size: 0.8125rem; cursor: pointer; background: #fff; border: 1px solid #adadad; border-radius: 2px; margin-right: 4px; }
    .btn-small:hover { border-color: #666; }
    .btn-danger { padding: 8px 14px; cursor: pointer; background: #fff; color: #b30000; border: 1px solid #d4a0a0; border-radius: 2px; font-size: 0.875rem; font-weight: 600; }
    .btn-danger:hover { background: #fff5f5; border-color: #b30000; }
    .btn-goto-visual { display: inline-flex; align-items: center; gap: 5px; padding: 8px 14px; cursor: pointer; background: #fff; color: #1976d2; border: 1px solid #90caf9; border-radius: 2px; font-size: 0.875rem; font-weight: 600; }
    .btn-goto-visual:hover { background: #e3f2fd; border-color: #1976d2; }
    #app-modal-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 1000; display: flex; align-items: flex-start; justify-content: center;
      padding: 40px 16px; overflow-y: auto;
    }
    #app-modal-overlay.hidden { display: none !important; }
    .modal-dialog {
      background: #fff; border-radius: 4px; max-width: 560px; width: 100%; box-shadow: 0 8px 32px rgba(0,0,0,.2); position: relative;
    }
    .modal-dialog.wide { max-width: 720px; }
    .cms-content-field-wrap { margin-bottom: 8px; }
    .cms-content-field-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px 12px;
      margin-top: 8px;
      align-items: center;
    }
    .cms-page-content-summary {
      margin: 8px 0 0;
      font-size: 0.8125rem;
      line-height: 1.4;
      word-break: break-word;
    }
    .cms-page-content-stack {
      max-width: none;
    }
    .cms-page-content-code {
      width: 100%;
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      font-size: 0.8125rem;
      line-height: 1.45;
      padding: 10px 12px;
      border: 1px solid #adadad;
      border-radius: 4px;
      resize: vertical;
      min-height: 280px;
      box-sizing: border-box;
    }
    .cms-page-grapes-workspace {
      display: none;
      flex: 1;
      flex-direction: column;
      min-height: 0;
      overflow: hidden;
      background: #f0f0f0;
      --cms-grapes-chrome-bg: #353d4a;
      --cms-grapes-chrome-fg: #e3e3e3;
      --cms-grapes-chrome-border: #2a3138;
    }
    .cms-page-grapes-workspace.hidden { display: none !important; }
    #main.cms-grapes-workspace-active #main-content {
      display: none !important;
    }
    #main.cms-grapes-workspace-active #toolbar {
      flex-shrink: 0;
      position: relative;
      z-index: 410;
    }
    body.cms-grapes-workspace-body #toolbar .toolbar-user-menu-panel {
      z-index: 420;
    }
    #main.cms-grapes-workspace-active .cms-page-grapes-workspace {
      display: flex !important;
    }
    .cms-page-grapes-workspace-toolbar {
      flex-shrink: 0;
      margin: 0;
      padding: 12px 20px;
      padding-inline-end: max(20px, var(--admin-toolbar-account-reserve));
      border-bottom: 1px solid #e3e3e3;
      background: #fafafa;
      box-sizing: border-box;
    }
    #cms-pages-editor-panel:not(.hidden) > .detail-edit-toolbar {
      padding-inline-end: var(--admin-toolbar-account-reserve);
      box-sizing: border-box;
    }
    .cms-page-grapes-workspace-title {
      margin: 0;
      font-size: 1.125rem;
      font-weight: 600;
      color: #303030;
    }
    .cms-page-grapes-host {
      flex: 1;
      min-height: 0;
      border: none;
      border-radius: 0;
      background: #f0f0f0;
      overflow: hidden;
      padding: 0 20px 20px;
      box-sizing: border-box;
    }
    #cms-page-grapes-root {
      height: 100%;
      min-height: 320px;
      box-sizing: border-box;
    }
    body.cms-grapes-workspace-body #sidebar {
      position: relative;
      z-index: 400;
    }
    body.cms-grapes-workspace-body #sidebar .menu,
    body.cms-grapes-workspace-body #sidebar .flyout-panel {
      pointer-events: auto;
    }
    #cms-page-grapes-root .gjs-editor {
      position: relative !important;
      inset: auto !important;
      width: 100% !important;
      max-width: 100% !important;
      height: 100% !important;
      box-sizing: border-box;
    }
    #cms-page-grapes-root .gjs-one-bg {
      background-color: var(--cms-grapes-chrome-bg) !important;
      border-color: var(--cms-grapes-chrome-border) !important;
    }
    #cms-page-grapes-root .gjs-pn-panel .gjs-two-color,
    #cms-page-grapes-root .gjs-pn-views .gjs-two-color,
    #cms-page-grapes-root .gjs-pn-commands .gjs-two-color,
    #cms-page-grapes-root .gjs-pn-options .gjs-two-color,
    #cms-page-grapes-root .gjs-pn-devices-c .gjs-two-color,
    #cms-page-grapes-root .gjs-cv-toolbar .gjs-two-color,
    #cms-page-grapes-root .gjs-sm-sector .gjs-two-color,
    #cms-page-grapes-root .gjs-trait-category .gjs-two-color {
      color: var(--cms-grapes-chrome-fg) !important;
    }
    #cms-page-grapes-root .gjs-three-bg {
      background-color: #2a3138 !important;
      color: var(--cms-grapes-chrome-fg) !important;
    }
    #cms-page-grapes-root .gjs-four-color,
    #cms-page-grapes-root .gjs-four-color-h:hover {
      color: #fff !important;
    }
    #cms-page-grapes-root .gjs-pn-panel,
    #cms-page-grapes-root .gjs-pn-views,
    #cms-page-grapes-root .gjs-pn-views-container,
    #cms-page-grapes-root .gjs-pn-options,
    #cms-page-grapes-root .gjs-pn-commands,
    #cms-page-grapes-root .gjs-pn-devices-c,
    #cms-page-grapes-root .gjs-cv-toolbar,
    #cms-page-grapes-root .gjs-toolbar {
      background-color: var(--cms-grapes-chrome-bg) !important;
      color: var(--cms-grapes-chrome-fg) !important;
      border-color: var(--cms-grapes-chrome-border) !important;
    }
    #cms-page-grapes-root .gjs-pn-btn {
      color: var(--cms-grapes-chrome-fg) !important;
    }
    #cms-page-grapes-root .gjs-pn-btn.gjs-pn-active {
      background-color: #2a3138 !important;
      color: #fff !important;
    }
    #cms-page-grapes-root .gjs-blocks-c,
    #cms-page-grapes-root .gjs-block-categories {
      background: #e8eaee !important;
      color: #1f2937 !important;
    }
    #cms-page-grapes-root .gjs-block-category .gjs-title {
      background-color: var(--cms-grapes-chrome-bg) !important;
      color: var(--cms-grapes-chrome-fg) !important;
      border-color: var(--cms-grapes-chrome-border) !important;
    }
    #cms-page-grapes-root .gjs-block {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      gap: 8px;
      width: 95%;
      min-height: 44px;
      margin: 6px 2.5%;
      padding: 6px 8px;
      background: #fff !important;
      color: #1f2937 !important;
      border: 1px solid #c5c9d0 !important;
      border-radius: 6px;
      box-shadow: 0 1px 2px rgba(17, 24, 39, 0.08) !important;
      overflow: hidden;
    }
    #cms-page-grapes-root .gjs-block:hover {
      border-color: #ff6b3d !important;
      box-shadow: 0 2px 8px rgba(17, 24, 39, 0.12) !important;
    }
    #cms-page-grapes-root .gjs-block__media {
      margin: 0 !important;
      flex: 0 0 14px;
      width: 14px;
      min-width: 14px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    #cms-page-grapes-root .gjs-block svg,
    #cms-page-grapes-root .gjs-block-svg,
    #cms-page-grapes-root .gjs-block-svg-path {
      width: 14px !important;
      height: 14px !important;
      fill: #4b5563 !important;
      color: #4b5563 !important;
    }
    #cms-page-grapes-root .gjs-block-label {
      color: #1f2937 !important;
      font-weight: 600;
      text-align: left;
      line-height: 1.2;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: normal;
      font-size: 11px;
    }
    #cms-page-grapes-root .gjs-sm-sector-title,
    #cms-page-grapes-root .gjs-trait-category .gjs-title {
      background-color: var(--cms-grapes-chrome-bg) !important;
      color: var(--cms-grapes-chrome-fg) !important;
      border-color: var(--cms-grapes-chrome-border) !important;
    }
    #cms-page-grapes-root .gjs-sm-properties,
    #cms-page-grapes-root .gjs-traits-c,
    #cms-page-grapes-root .gjs-clm-tags {
      background: #e8eaee !important;
      color: #1f2937 !important;
    }
    /* GrapesJS resize handles — visible grips on all edges when a block is selected */
    #cms-page-grapes-root .gjs-resizer-h {
      opacity: 1;
      border: none;
      background-color: #fff;
      box-shadow: 0 0 0 2px #2563eb, 0 2px 6px rgba(15, 23, 42, 0.18);
      background-repeat: no-repeat;
      background-position: center;
      background-size: 14px 14px;
      z-index: 30;
      transition: box-shadow 0.15s ease, transform 0.15s ease;
    }
    #cms-page-grapes-root .gjs-resizer-h:hover {
      opacity: 1;
      box-shadow: 0 0 0 2px #1d4ed8, 0 3px 10px rgba(37, 99, 235, 0.35);
      transform: scale(1.08);
    }
    #cms-page-grapes-root .gjs-resizer-h-tl,
    #cms-page-grapes-root .gjs-resizer-h-br {
      width: 14px;
      height: 14px;
      cursor: nwse-resize;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='none' stroke='%232563eb' stroke-width='1.5' stroke-linecap='round' d='M2 12L12 2M5 12h7v-7'/%3E%3C/svg%3E");
    }
    #cms-page-grapes-root .gjs-resizer-h-tr,
    #cms-page-grapes-root .gjs-resizer-h-bl {
      width: 14px;
      height: 14px;
      cursor: nesw-resize;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='none' stroke='%232563eb' stroke-width='1.5' stroke-linecap='round' d='M12 12L2 2M9 12H2V5'/%3E%3C/svg%3E");
    }
    #cms-page-grapes-root .gjs-resizer-h-tc,
    #cms-page-grapes-root .gjs-resizer-h-bc {
      width: 36px;
      height: 12px;
      margin: 0 auto;
      cursor: ns-resize;
      border-radius: 6px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='none' stroke='%232563eb' stroke-width='1.5' stroke-linecap='round' d='M7 3v8M4 6l3-3 3 3M4 8l3 3 3-3'/%3E%3C/svg%3E");
    }
    #cms-page-grapes-root .gjs-resizer-h-cl,
    #cms-page-grapes-root .gjs-resizer-h-cr {
      width: 12px;
      height: 36px;
      margin: auto 0;
      cursor: ew-resize;
      border-radius: 6px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='none' stroke='%232563eb' stroke-width='1.5' stroke-linecap='round' d='M3 7h8M6 4L3 7l3 3M8 4l3 3-3 3'/%3E%3C/svg%3E");
    }
    .cms-trait-asset-url {
      display: flex;
      align-items: center;
      gap: 6px;
      width: 100%;
    }
    .cms-trait-asset-url-input {
      flex: 1;
      min-width: 0;
    }
    .cms-trait-asset-picker-btn {
      flex: 0 0 auto;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 32px;
      height: 32px;
      padding: 0;
      border: 1px solid #c5c9d0;
      border-radius: 4px;
      background: #fff;
      color: #2563eb;
      cursor: pointer;
    }
    .cms-trait-asset-picker-btn:hover {
      background: #eff6ff;
      border-color: #2563eb;
    }
    .cms-trait-row-bg-color {
      display: flex;
      align-items: center;
      gap: 8px;
      width: 100%;
    }
    .cms-trait-row-bg-color-input {
      width: 100%;
      height: 32px;
      padding: 2px;
      border: 1px solid #c4c4c4;
      border-radius: 4px;
      cursor: pointer;
      background: #fff;
    }
    .cms-grapes-asset-picker-overlay {
      position: fixed;
      inset: 0;
      z-index: 500;
      background: rgba(0, 0, 0, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px;
      box-sizing: border-box;
    }
    .cms-grapes-asset-picker-overlay.hidden {
      display: none !important;
    }
    body.cms-grapes-asset-picker-open {
      overflow: hidden;
    }
    .cms-grapes-asset-picker-dialog {
      background: #fff;
      border-radius: 6px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
      width: min(1200px, 96vw);
      height: min(720px, 92vh);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }
    .cms-grapes-asset-picker-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 12px 16px;
      border-bottom: 1px solid #e5e7eb;
    }
    .cms-grapes-asset-picker-header h3 {
      margin: 0;
      font-size: 1.0625rem;
    }
    .cms-grapes-asset-picker-gallery .media-gallery-topbar--with-selection {
      justify-content: space-between;
      gap: 12px;
    }
    .cms-grapes-asset-picker-gallery .media-gallery-topbar-selected {
      flex: 1 1 auto;
      min-width: 0;
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      font-size: 0.8125rem;
      color: #374151;
      text-align: left;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .cms-grapes-asset-picker-gallery .media-gallery-topbar-actions {
      flex: 0 0 auto;
      margin-left: auto;
    }
    .cms-grapes-asset-picker-gallery {
      flex: 1;
      min-height: 0;
      display: flex;
      flex-direction: column;
    }
    .cms-grapes-asset-picker-gallery .media-gallery-body {
      flex: 1;
      min-height: 0;
    }
    #cms-grapes-asset-picker-use-btn:disabled {
      opacity: 0.45;
      cursor: not-allowed;
    }
    .cms-trait-block-ref {
      display: flex;
      align-items: center;
      gap: 6px;
      width: 100%;
    }
    .cms-trait-block-ref-input {
      flex: 1;
      min-width: 0;
    }
    .cms-trait-block-ref-picker-btn {
      flex: 0 0 auto;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 32px;
      height: 32px;
      padding: 0;
      border: 1px solid #c4c4c4;
      border-radius: 4px;
      background: #fff;
      cursor: pointer;
      color: #303030;
    }
    .cms-trait-block-ref-picker-btn:hover {
      background: #f3f4f6;
      border-color: #2563eb;
    }
    .cms-grapes-block-picker-overlay {
      position: fixed;
      inset: 0;
      z-index: 500;
      background: rgba(0, 0, 0, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px;
      box-sizing: border-box;
    }
    .cms-grapes-block-picker-overlay.hidden {
      display: none !important;
    }
    body.cms-grapes-block-picker-open {
      overflow: hidden;
    }
    .cms-grapes-block-picker-dialog {
      background: #fff;
      border-radius: 6px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
      width: min(960px, 96vw);
      max-height: min(720px, 92vh);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      padding: 0 0 12px;
    }
    .cms-grapes-block-picker-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 12px 16px;
      border-bottom: 1px solid #e5e7eb;
    }
    .cms-grapes-block-picker-header h3 {
      margin: 0;
      font-size: 1.0625rem;
    }
    .cms-grapes-block-picker-toolbar {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 12px 16px 0;
      flex-wrap: wrap;
    }
    .cms-grapes-block-picker-search {
      flex: 1;
      min-width: 180px;
      height: 32px;
      padding: 4px 10px;
      border: 1px solid #c4c4c4;
      border-radius: 4px;
      font-size: 0.875rem;
    }
    .cms-grapes-block-picker-toolbar-actions {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
    }
    #cms-grapes-block-picker-copy-btn:disabled,
    #cms-grapes-block-picker-use-btn:disabled {
      opacity: 0.45;
      cursor: not-allowed;
    }
    #cms-grapes-block-picker-content {
      flex: 1;
      min-height: 0;
      overflow: auto;
      padding: 12px 16px;
    }
    .cms-grapes-block-picker-card-code {
      font-size: 0.7rem;
      color: #666;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      margin-top: 2px;
    }
    .cms-grapes-block-picker-letter {
      font-size: 1.75rem;
      font-weight: 600;
      color: #9ca3af;
    }
    .cms-grapes-widget-picker-overlay {
      position: fixed;
      inset: 0;
      z-index: 500;
      background: rgba(0, 0, 0, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px;
    }
    .cms-grapes-widget-picker-overlay.hidden {
      display: none !important;
    }
    body.cms-grapes-widget-picker-open {
      overflow: hidden;
    }
    .cms-grapes-widget-picker-dialog {
      background: #fff;
      border-radius: 6px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
      width: min(1100px, 96vw);
      height: min(720px, calc(100vh - 40px));
      max-height: calc(100vh - 40px);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }
    .cms-grapes-widget-picker-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 18px;
      border-bottom: 1px solid #e5e7eb;
    }
    .cms-grapes-widget-picker-header h3 {
      margin: 0;
      font-size: 1.0625rem;
    }
    .cms-grapes-widget-picker-toolbar {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 18px;
      border-bottom: 1px solid #e5e7eb;
    }
    .cms-grapes-widget-picker-search {
      flex: 1;
      min-width: 180px;
      height: 32px;
      padding: 0 10px;
      border: 1px solid #d1d5db;
      border-radius: 4px;
    }
    .cms-grapes-widget-picker-toolbar-actions {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
    }
    #cms-grapes-widget-picker-copy-btn:disabled {
      opacity: 0.45;
      cursor: not-allowed;
    }
    .cms-grapes-widget-picker-body {
      flex: 1;
      min-height: 0;
      display: grid;
      grid-template-columns: 1fr minmax(260px, 340px);
      gap: 0;
      overflow: hidden;
    }
    #cms-grapes-widget-picker-content {
      flex: 1;
      min-height: 0;
      overflow: auto;
      padding: 12px 18px;
    }
    .cms-grapes-widget-picker-config-wrap {
      border-left: 1px solid #e5e7eb;
      padding: 12px 16px;
      overflow: auto;
      background: #fafafa;
    }
    .cms-grapes-widget-picker-config-wrap.hidden {
      display: none !important;
    }
    .cms-grapes-widget-picker-config-title {
      margin: 0 0 10px;
      font-size: 0.9375rem;
      font-weight: 600;
    }
    .cms-grapes-widget-config-panel label {
      display: block;
      margin: 0 0 4px;
      font-size: 0.8125rem;
      font-weight: 500;
    }
    .cms-grapes-widget-config-panel input[type="text"],
    .cms-grapes-widget-config-panel textarea {
      width: 100%;
      box-sizing: border-box;
      margin-bottom: 10px;
      padding: 6px 8px;
      border: 1px solid #d1d5db;
      border-radius: 4px;
      font-size: 0.875rem;
    }
    .cms-trait-widget-ref {
      display: flex;
      gap: 6px;
      align-items: center;
    }
    .cms-trait-widget-ref-input {
      flex: 1;
      min-width: 0;
    }
    .cms-trait-widget-ref-config-input {
      width: 100%;
      font-family: ui-monospace, monospace;
      font-size: 0.8125rem;
    }
    .cms-content-preview-dialog {
      width: min(1400px, 98vw);
      height: min(92vh, 960px);
      max-height: 92vh;
    }
    .cms-content-preview-dialog .cms-rich-editor-frame {
      min-height: 520px;
    }
    body.cms-grapes-workspace-body {
      overflow: hidden;
    }
    body.cms-rich-editor-body-lock { overflow: hidden; }
    .cms-rich-editor-overlay {
      position: fixed;
      inset: 0;
      z-index: 200;
      background: rgba(0, 0, 0, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px;
    }
    .cms-rich-editor-overlay.hidden { display: none !important; }
    .cms-rich-editor-dialog {
      background: #fff;
      border-radius: 4px;
      box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
      width: min(1100px, 96vw);
      height: min(720px, calc(100vh - 40px));
      max-height: calc(100vh - 40px);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }
    .cms-rich-editor-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 18px 8px;
      border-bottom: 1px solid #e5e5e5;
    }
    .cms-rich-editor-header h3 {
      margin: 0;
      font-size: 1.125rem;
      font-weight: 600;
      color: #303030;
    }
    .cms-rich-editor-hint {
      margin: 0;
      padding: 0 18px 10px;
      font-size: 0.8125rem;
    }
    .cms-rich-editor-frame {
      flex: 1;
      width: 100%;
      min-height: 360px;
      border: none;
      background: #f0f0f0;
      display: block;
    }
    .cms-rich-editor-footer {
      display: flex;
      justify-content: flex-end;
      gap: 10px;
      padding: 12px 18px 16px;
      border-top: 1px solid #e5e5e5;
      background: #fafafa;
    }
    .modal-dialog h3 { margin: 0; padding: 16px 20px; border-bottom: 1px solid #e3e3e3; font-size: 1.1rem; }
    .modal-body { padding: 16px 20px; max-height: 60vh; overflow-y: auto; }
    .modal-body label { display: block; font-size: 0.8125rem; font-weight: 600; margin-bottom: 4px; color: #444; }
    .modal-body input[type="text"], .modal-body input[type="email"], .modal-body input[type="password"], .modal-body textarea { width: 100%; padding: 8px 10px; margin-bottom: 12px; border: 1px solid #adadad; border-radius: 2px; font-family: inherit; font-size: 0.875rem; }
    .modal-body textarea { min-height: 72px; resize: vertical; }
    .modal-footer { padding: 12px 20px; border-top: 1px solid #e3e3e3; display: flex; justify-content: flex-end; gap: 8px; }
    .info-modal-inner { display: flex; gap: 16px; align-items: flex-start; }
    .info-modal-icon { flex-shrink: 0; color: #2563eb; margin-top: 2px; line-height: 0; }
    .info-modal-text { flex: 1; min-width: 0; }
    .info-modal-message { margin: 0 0 10px 0; font-size: 0.9375rem; line-height: 1.5; color: #1a1a1a; }
    .info-modal-detail { margin: 0; font-size: 0.8125rem; line-height: 1.45; color: #555; }
    .admin-idle-warning-icon { color: #d97706; }
    .admin-idle-warning-countdown-wrap { margin: 0; font-size: 0.9375rem; color: #1a1a1a; }
    .admin-idle-warning-countdown { font-size: 1.125rem; font-variant-numeric: tabular-nums; color: #b45309; }
    .cron-control-bar { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 12px 16px; margin-bottom: 16px; padding: 12px 14px; background: #fff; border: 1px solid #e5e5e5; border-radius: 6px; }
    .cron-info-open-btn {
      margin-right: auto;
      display: inline-flex; align-items: center; justify-content: center;
      padding: 0; border: none; background: none; cursor: pointer;
      color: #2563eb; line-height: 0;
    }
    .cron-info-open-btn:hover { color: #1d4ed8; }
    .modal-dialog.cron-info-modal { max-width: 920px; }
    .modal-dialog.cron-info-modal > h3 { display: none; }
    .modal-dialog.cron-info-modal .modal-body { max-height: 70vh; padding-top: 20px; }
    .dev-terminal-wrap { max-width: 960px; background: #1e1e1e; border: 1px solid #333; border-radius: 8px; padding: 0; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.12); }
    .dev-terminal-output { min-height: 360px; max-height: 52vh; overflow-y: auto; padding: 14px 16px; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 13px; line-height: 1.45; color: #d4d4d4; white-space: pre-wrap; word-break: break-word; }
    .dev-terminal-line--cmd { color: #9cdcfe; }
    .dev-terminal-line--ok { color: #d4d4d4; }
    .dev-terminal-line--err { color: #f48771; }
    .dev-terminal-line--muted { color: #858585; }
    .dev-terminal-input-row { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: #252526; border-top: 1px solid #3c3c3c; }
    .dev-terminal-prompt { color: #4ec9b0; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 13px; flex-shrink: 0; user-select: none; }
    .dev-terminal-input { flex: 1; min-width: 0; background: #1e1e1e; border: 1px solid #3c3c3c; border-radius: 4px; color: #d4d4d4; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 13px; padding: 8px 10px; }
    .dev-terminal-input:focus { outline: none; border-color: #569cd6; box-shadow: 0 0 0 2px rgba(86,156,214,.25); }
    .dev-terminal-input:disabled { opacity: 0.65; cursor: wait; }

    .dev-svg-edit-view { margin: -20px -24px; min-height: calc(100vh - 64px); }
    .dev-svg-edit-layout { display: flex; gap: 0; min-height: calc(100vh - 64px); align-items: stretch; }
    .dev-svg-edit-sidebar {
      width: 240px; flex-shrink: 0; background: #353d4a; color: #e3e3e3;
      border-right: 1px solid #2a3138; padding: 12px 10px; display: flex; flex-direction: column;
      max-height: calc(100vh - 64px); transition: width .2s ease, padding .2s ease, opacity .2s ease;
      overflow: hidden;
    }
    .dev-svg-edit-layout.is-sidebar-collapsed .dev-svg-edit-sidebar {
      width: 0; min-width: 0; padding: 0; border-right-width: 0; opacity: 0; pointer-events: none;
    }
    .dev-svg-edit-sidebar-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 8px; flex-shrink: 0; }
    .dev-svg-edit-sidebar-head strong { font-size: 0.875rem; letter-spacing: .02em; }
    .dev-svg-edit-sidebar-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
    .dev-svg-edit-sidebar-toggle {
      display: inline-flex; align-items: center; justify-content: center;
      width: 28px; height: 28px; padding: 0; border: 1px solid #4a5564;
      border-radius: 50%; background: transparent; cursor: pointer; color: #c5c5c5; flex-shrink: 0;
    }
    .dev-svg-edit-sidebar-toggle:hover { border-color: #eb5202; color: #fff; background: rgba(255,255,255,.06); }
    .dev-svg-edit-sidebar-expand {
      display: inline-flex; flex-direction: column; align-items: center; justify-content: flex-start;
      width: 36px; min-width: 36px; padding: 12px 0 0; align-self: stretch; flex-shrink: 0;
      border: none; border-radius: 0; border-right: 1px solid #2a3138;
      background: #353d4a; color: #e3e3e3; cursor: pointer;
    }
    .dev-svg-edit-sidebar-expand:hover { background: #3d4654; color: #fff; }
    .dev-svg-edit-layout.is-sidebar-collapsed .dev-svg-edit-sidebar-expand { background: #353d4a; }
    .dev-svg-edit-btn-on-dark { background: rgba(255,255,255,.08); border-color: #4a5564; color: #e3e3e3; }
    .dev-svg-edit-btn-on-dark:hover { background: rgba(255,255,255,.12); border-color: #6b7280; color: #fff; }
    .dev-svg-edit-sidebar-body { display: flex; flex-direction: column; flex: 1; min-height: 0; }
    .dev-svg-edit-list-msg { margin: 0 0 8px; font-size: 0.8125rem; color: #9ca3af; }
    .dev-svg-edit-list-msg.error { color: #f87171; }
    .dev-svg-edit-file-list { list-style: none; margin: 0; padding: 0; overflow-y: auto; flex: 1; }
    .dev-svg-edit-file-item { margin: 0 0 2px; }
    .dev-svg-edit-file-btn {
      width: 100%; text-align: left; padding: 8px 10px; border: none; border-left: 4px solid transparent;
      border-radius: 0; background: transparent; cursor: pointer; font-size: 0.8125rem; color: inherit;
    }
    .dev-svg-edit-file-btn:hover { background: rgba(255,255,255,.06); color: #fff; }
    .dev-svg-edit-file-btn.active { background: rgba(235,82,2,.12); border-left-color: #eb5202; color: #fff; font-weight: 600; }
    .dev-svg-edit-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0; background: #353d4a; }
    .dev-svg-edit-toolbar {
      display: flex; flex-wrap: nowrap; align-items: center; gap: 8px;
      padding: 8px 12px; background: #3d4654; border-bottom: 1px solid #2a3138; flex-shrink: 0;
    }
    .dev-svg-edit-toolbar-file-label { font-size: 0.8125rem; color: #c5c5c5; white-space: nowrap; flex-shrink: 0; }
    .dev-svg-edit-filename { flex: 1 1 140px; min-width: 100px; max-width: 280px; }
    .dev-svg-edit-toolbar .btn-primary,
    .dev-svg-edit-toolbar .btn-secondary,
    .dev-svg-edit-toolbar .btn-danger-outline { flex-shrink: 0; }
    .dev-svg-edit-toolbar .btn-secondary {
      padding: 8px 14px; cursor: pointer; background: rgba(255,255,255,.08); color: #e3e3e3;
      border: 1px solid #4a5564; border-radius: 2px; font-size: 0.875rem; font-weight: 600;
    }
    .dev-svg-edit-toolbar .btn-secondary:hover:not(:disabled) {
      background: rgba(255,255,255,.12); border-color: #6b7280; color: #fff;
    }
    .dev-svg-edit-toolbar .btn-secondary:disabled { opacity: 0.5; cursor: not-allowed; }
    .dev-svg-edit-toolbar .btn-danger-outline {
      background: rgba(255,255,255,.06); color: #fca5a5; border-color: #7f1d1d;
    }
    .dev-svg-edit-toolbar .btn-danger-outline:hover:not(:disabled) {
      background: rgba(248,113,113,.15); border-color: #f87171; color: #fecaca;
    }
    .dev-svg-edit-status { margin-left: auto; font-size: 0.8125rem; color: #9ca3af; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
    .dev-svg-edit-status.error { color: #f87171; }
    .dev-svg-edit-frame { flex: 1; min-height: 0; width: 100%; border: none; border-radius: 0; background: #353d4a; }
    .dev-svg-edit-preview-overlay { position: fixed; inset: 0; z-index: 12000; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; padding: 24px; }
    .dev-svg-edit-preview-dialog { background: #fff; border-radius: 10px; width: min(720px, 100%); max-height: 90vh; display: flex; flex-direction: column; box-shadow: 0 12px 40px rgba(0,0,0,.2); }
    .dev-svg-edit-preview-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid #e5e7eb; }
    .dev-svg-edit-preview-header h3 { margin: 0; font-size: 1rem; }
    .dev-svg-edit-preview-body { padding: 20px; overflow: auto; display: flex; align-items: center; justify-content: center; min-height: 200px; background: #fafafa; }
    .dev-svg-edit-preview-img { max-width: 100%; max-height: 52vh; object-fit: contain; }
    .dev-svg-edit-preview-footer { display: flex; justify-content: flex-end; gap: 10px; padding: 12px 16px; border-top: 1px solid #e5e7eb; }
    .btn-danger-outline { background: #fff; color: #c61f1f; border: 1px solid #f0b4b4; border-radius: 4px; padding: 8px 14px; cursor: pointer; font-size: 0.875rem; }
    .btn-danger-outline:hover:not(:disabled) { background: #fff5f5; }
    .btn-danger-outline:disabled { opacity: 0.5; cursor: not-allowed; }
    .btn-sm { padding: 6px 10px; font-size: 0.8125rem; }
    .label-info-stack-wrap { max-width: none; width: 100%; }
    .label-info-stack-table { width: 100%; }
    .label-info-stack-table td, .label-info-stack-table th { vertical-align: top; }
    .dev-info-sections { display: flex; flex-direction: column; gap: 24px; max-width: 1100px; }
    .dev-info-section-title { margin: 0 0 8px; font-size: 1rem; font-weight: 700; }
    .dev-info-table { width: 100%; }
    .dev-info-table th[scope="row"] { width: 220px; white-space: nowrap; }
    .dev-info-link { word-break: break-all; }
    .dev-info-note, .dev-info-muted { color: #6b7280; font-size: 0.875rem; }
    .label-info-menu-tree-root { max-width: 720px; background: #fff; border: 1px solid #d1d1d1; border-radius: 6px; padding: 16px 20px; font-size: 0.9rem; }
    .label-info-menu-tree__level1 { list-style: none; margin: 0; padding: 0; }
    .label-info-menu-tree__l1-row { margin: 0 0 16px; padding: 0 0 14px; border-bottom: 1px solid #e8e8e8; }
    .label-info-menu-tree__l1-row:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
    .label-info-menu-tree__l1 { font-size: 1rem; font-weight: 600; color: #303030; margin: 0 0 6px; }
    .label-info-menu-tree__l1-meta { margin: 0 0 4px; font-size: 0.8rem; }
    .label-info-menu-tree__level2 { margin: 4px 0 0 12px; padding: 0 0 0 10px; border-left: 2px solid #eb5202; }
    .label-info-menu-tree__l2 { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: #64748b; margin: 8px 0 4px; }
    .label-info-menu-tree__level2:first-child .label-info-menu-tree__l2 { margin-top: 0; }
    .label-info-menu-tree__level3 { list-style: none; margin: 0 0 8px; padding: 0 0 0 8px; }
    .label-info-menu-tree__level3--flat { margin-top: 4px; padding-left: 10px; border-left: 2px solid #eb5202; }
    .label-info-menu-tree__l3 { margin: 0 0 4px; padding: 3px 0; display: flex; flex-direction: column; gap: 2px; }
    .label-info-menu-tree__l3-label { font-weight: 500; color: #303030; }
    .label-info-menu-tree__meta { font-size: 0.8rem; color: #64748b; }
    .label-info-menu-tree__meta code { font-size: 0.78rem; }
    .cron-control-label { font-size: 0.875rem; color: #444; display: inline-flex; align-items: center; gap: 8px; }
    .cron-master-select { min-width: 110px; padding: 6px 8px; }
    .cron-status-pill { font-weight: 600; }
    .cron-status-pill--on { color: #15803d; }
    .cron-status-pill--off { color: #b45309; }
    .queue-status-pill {
      display: inline-block;
      padding: 2px 8px;
      border-radius: 999px;
      font-size: 0.8rem;
      font-weight: 600;
      line-height: 1.4;
      background: #f3f4f6;
      color: #374151;
    }
    .queue-status-pill--new { background: #eff6ff; color: #1d4ed8; }
    .queue-status-pill--running { background: #fff7ed; color: #c2410c; }
    .queue-status-pill--done { background: #ecfdf5; color: #15803d; }
    .queue-status-pill--error { background: #fef2f2; color: #b91c1c; }
    .tasks-queue-error-block {
      margin: 0;
      padding: 12px 14px;
      background: #1f2937;
      color: #f9fafb;
      border-radius: 6px;
      font-size: 0.85rem;
      line-height: 1.5;
      white-space: pre-wrap;
      word-break: break-word;
      overflow: auto;
      max-height: 480px;
    }
    .perm-check-grid { display: grid; gap: 8px; grid-template-columns: 1fr; margin-top: 8px; }
    .perm-check { display: flex; align-items: flex-start; gap: 8px; padding: 8px; border: 1px solid #eee; border-radius: 4px; background: #fafafa; }
    .perm-check input { margin-top: 3px; }
    .perm-check .perm-title { font-weight: 600; font-size: 0.875rem; color: #222; }
    .perm-check .perm-code { font-size: 0.75rem; color: #666; font-family: ui-monospace, monospace; }
    .modal-error { color: #b30000; font-size: 0.875rem; margin-bottom: 8px; }
    .modal-close { position: absolute; top: 12px; right: 14px; border: none; background: none; font-size: 1.5rem; line-height: 1; cursor: pointer; color: #666; }
    .modal-close:hover { color: #000; }

    #confirm-overlay {
      position: fixed; inset: 0; z-index: 1100;
      background: rgba(18, 22, 30, 0.55);
      backdrop-filter: blur(3px);
      display: flex; align-items: center; justify-content: center;
      padding: 24px;
    }
    #confirm-overlay.hidden { display: none !important; }
    .confirm-dialog {
      width: 100%; max-width: 420px;
      background: #fff;
      border-radius: 12px;
      box-shadow: 0 24px 48px rgba(0,0,0,.28), 0 0 0 1px rgba(0,0,0,.06);
      padding: 28px 28px 22px;
      text-align: center;
      animation: confirmPop 0.22s ease-out;
    }
    @keyframes confirmPop {
      from { opacity: 0; transform: scale(0.94) translateY(8px); }
      to { opacity: 1; transform: scale(1) translateY(0); }
    }
    .confirm-icon-wrap {
      width: 64px; height: 64px; margin: 0 auto 16px;
      border-radius: 50%;
      background: linear-gradient(145deg, #ffe8e0 0%, #ffd0c2 100%);
      display: flex; align-items: center; justify-content: center;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
    }
    .confirm-dialog h3 { margin: 0 0 10px; font-size: 1.2rem; font-weight: 700; color: #1a1d24; }
    .confirm-msg { margin: 0 0 8px; font-size: 0.9rem; color: #4a4f5c; line-height: 1.45; }
    .confirm-detail {
      margin: 0 0 22px; padding: 10px 12px; background: #f4f5f8; border-radius: 8px;
      font-size: 0.8125rem; color: #303540; font-family: ui-monospace, monospace; word-break: break-all;
    }
    .confirm-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
    .confirm-actions .btn-cancel {
      padding: 10px 20px; border-radius: 8px; border: 1px solid #c5c9d4; background: #fff;
      font-size: 0.9rem; font-weight: 600; cursor: pointer; color: #3d4250; font-family: inherit;
    }
    .confirm-actions .btn-cancel:hover { background: #f8f9fb; border-color: #a8aebc; }
    .confirm-actions .btn-confirm-danger {
      padding: 10px 22px; border-radius: 8px; border: none;
      background: linear-gradient(180deg, #e54545 0%, #c61f1f 100%);
      font-size: 0.9rem; font-weight: 700; cursor: pointer; color: #fff; font-family: inherit;
      box-shadow: 0 2px 8px rgba(198, 31, 31, 0.35);
    }
    .confirm-actions .btn-confirm-danger:hover { filter: brightness(1.05); }
    .status-badge { display:inline-block; padding:2px 8px; border-radius:3px; font-size:0.8rem; font-weight:600; line-height:1.4; white-space:nowrap; }
    .status-badge-draft { background:#fff8e1; color:#8d6e00; border:1px solid #ffe082; }
    .status-badge-enabled { background:#e8f5e9; color:#2e7d32; border:1px solid #a5d6a7; }
    .visibility-badge-public { background:#e3f2fd; color:#1565c0; border:1px solid #90caf9; }
    .visibility-badge-private { background:#f3e5f5; color:#6a1b9a; border:1px solid #ce93d8; }
    .status-badge-disabled { background:#ffebee; color:#b71c1c; border:1px solid #ef9a9a; }
    .status-badge-invalidated { background:#fff8e1; color:#e65100; border:1px solid #ffcc80; }
    .status-badge-missing { background:#fce4ec; color:#ad1457; border:1px solid #f48fb1; }
    .i18n-admin-toolbar-top {
      display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
      gap: 12px 20px; width: 100%; padding-bottom: 10px; border-bottom: 1px solid #e8e8e8;
    }
    .i18n-admin-toolbar-missing {
      display: flex; flex-wrap: wrap; align-items: center; gap: 8px 6px; flex: 1 1 auto; min-width: 0;
    }
    .i18n-missing-title { font-weight: 600; font-size: 0.875rem; color: #303030; }
    .i18n-missing-stats { display: inline-flex; flex-wrap: wrap; align-items: center; gap: 2px 0; line-height: 1.4; }
    .i18n-missing-sep { margin: 0 10px; color: #bbb; font-weight: 400; }
    .i18n-missing-stat { font-size: 0.875rem; white-space: nowrap; }
    .i18n-missing-stat-locale { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 600; }
    .i18n-missing-stat--alert { color: #b71c1c; }
    .i18n-missing-stat--alert .i18n-missing-stat-count { font-weight: 700; }
    .i18n-missing-stat--ok { color: #2e7d32; }
    .i18n-missing-stat--ok .i18n-missing-stat-count { font-weight: 600; }
    .i18n-admin-toolbar-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; flex-shrink: 0; }
    .btn-i18n-io {
      display: inline-flex; align-items: center; justify-content: center;
      padding: 7px 16px; font-size: 0.875rem; font-family: inherit; font-weight: 600;
      border-radius: 6px; cursor: pointer; line-height: 1.25; transition: background 0.15s, border-color 0.15s;
    }
    .btn-i18n-io-import {
      color: #303030; background: #fff; border: 1px solid #c5c5c5;
    }
    .btn-i18n-io-import:hover { background: #f3f4f6; border-color: #9ca3af; }
    .btn-i18n-io-export {
      color: #fff; background: #eb5202; border: 1px solid #d94802;
    }
    .btn-i18n-io-export:hover { background: #d94802; border-color: #c44002; }
    .lang-flag-picker-label { display: block; margin: 10px 0 6px; font-size: 0.875rem; font-weight: 600; }
    .lang-flag-picker {
      display: grid; grid-template-columns: repeat(auto-fill, minmax(44px, 1fr)); gap: 6px;
      max-height: 168px; overflow: auto; padding: 6px; border: 1px solid #e5e7eb; border-radius: 6px;
      background: #fafafa;
    }
    .lang-flag-picker__btn {
      display: inline-flex; align-items: center; justify-content: center;
      min-height: 40px; font-size: 1.35rem; line-height: 1;
      border: 1px solid #d1d5db; border-radius: 6px; background: #fff; cursor: pointer;
    }
    .lang-flag-picker__btn:hover { border-color: #9ca3af; background: #f9fafb; }
    .lang-flag-picker__btn--active {
      border-color: #eb5202; box-shadow: 0 0 0 1px #eb5202; background: #fff7ed;
    }
    .i18n-entity-type-flag { margin-left: 4px; font-size: 1rem; line-height: 1; }
    .entity-i18n-src-lang-th { width: 3.25rem; text-align: center; white-space: nowrap; }
    .entity-i18n-src-lang-cell { text-align: center; vertical-align: middle; width: 3.25rem; }
    .entity-i18n-src-lang-flag { font-size: 1.125rem; line-height: 1; }
    .entity-i18n-src-lang-code { font-size: 0.75rem; color: #666; }
    .entity-i18n-name-cell { display: flex; align-items: center; gap: 6px; min-width: 0; }
    .entity-i18n-name-cell .entity-i18n-name-text { min-width: 0; flex: 1 1 auto; }
    .entity-i18n-field-mark {
      flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center;
      width: 26px; height: 26px; padding: 0; border: none; border-radius: 4px;
      background: transparent; cursor: pointer;
    }
    .entity-i18n-field-mark:hover .entity-i18n-translate-icon { opacity: 0.88; }
    .entity-i18n-translate-icon { display: block; }
    .entity-i18n-label { display: flex; flex-direction: column; gap: 4px; }
    .entity-i18n-label-inner { display: inline-flex; align-items: center; gap: 6px; }
    .entity-i18n-label--pending .entity-i18n-field-mark { opacity: 0.55; cursor: help; }
    .entity-i18n-src-lang-filter select { min-width: 10rem; }
    .i18n-entity-edit-layout { display: flex; flex-direction: column; gap: 0; width: 100%; }
    .i18n-entity-edit-meta {
      width: 100%; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid #e5e7eb;
    }
    .i18n-entity-edit-meta-labels,
    .i18n-entity-edit-meta-values {
      display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px 20px; width: 100%;
    }
    .i18n-entity-edit-meta-labels {
      font-size: 0.8125rem; font-weight: 600; color: #666; margin-bottom: 6px;
    }
    .i18n-entity-edit-meta-values {
      font-size: 0.875rem; color: #303030; word-break: break-word;
    }
    @media (max-width: 720px) {
      .i18n-entity-edit-meta-labels,
      .i18n-entity-edit-meta-values { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }
    .i18n-entity-edit-columns {
      display: grid; grid-template-columns: 1fr 1fr; gap: 20px; width: 100%; align-items: start;
    }
    @media (max-width: 900px) {
      .i18n-entity-edit-columns { grid-template-columns: 1fr; }
    }
    .i18n-entity-edit-col h3 {
      margin: 0 0 12px; font-size: 0.9375rem; font-weight: 600; color: #303030;
      padding-bottom: 8px; border-bottom: 1px solid #e5e7eb;
    }
    .i18n-entity-edit-field-row {
      display: grid; grid-template-columns: 1fr; gap: 6px; margin-bottom: 14px;
    }
    .i18n-entity-edit-field-label {
      font-size: 0.8125rem; font-weight: 600; color: #666;
    }
    .i18n-entity-edit-field-value {
      font-size: 0.875rem; color: #303030; word-break: break-word;
    }
    .i18n-entity-edit-field-value--empty { color: #9ca3af; font-style: italic; }
    .i18n-entity-edit-col--translation .i18n-entity-field-input {
      width: 100%; font-size: 0.875rem;
    }
    .i18n-admin-modal-form { display: flex; flex-direction: column; gap: 16px; }
    .i18n-admin-modal-form .i18n-modal-hint {
      margin: 0; font-size: 0.8125rem; color: #666; line-height: 1.45;
    }
    .i18n-admin-modal-form .i18n-modal-hint code {
      font-size: 0.78rem; background: #f3f4f6; padding: 1px 5px; border-radius: 3px;
    }
    .i18n-modal-field { display: flex; flex-direction: column; gap: 8px; }
    .i18n-modal-field-label {
      font-size: 0.8125rem; font-weight: 600; color: #444; margin: 0;
    }
    .i18n-modal-select {
      width: 100%; padding: 8px 32px 8px 12px; font-size: 0.875rem; font-family: inherit;
      border: 1px solid #c5c5c5; border-radius: 6px; background: #fff;
      color: #303030; cursor: pointer; appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
      background-repeat: no-repeat; background-position: right 10px center;
    }
    .i18n-modal-select:hover { border-color: #9ca3af; background-color: #fafafa; }
    .i18n-modal-select:focus { outline: none; border-color: #eb5202; box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.2); }
    .i18n-modal-radio-group { display: flex; flex-direction: column; gap: 8px; }
    .i18n-modal-radio {
      display: flex; align-items: center; gap: 10px; margin: 0; padding: 10px 12px;
      border: 1px solid #e3e3e3; border-radius: 6px; background: #fafafa; cursor: pointer;
      font-size: 0.875rem; font-weight: 500; color: #303030;
    }
    .i18n-modal-radio:hover { border-color: #c5c5c5; background: #fff; }
    .i18n-modal-radio:has(input:checked) {
      border-color: #eb5202; background: #fff5f0; box-shadow: 0 0 0 1px rgba(235, 82, 2, 0.15);
    }
    .i18n-modal-radio input { margin: 0; accent-color: #eb5202; width: 16px; height: 16px; flex-shrink: 0; }
    .i18n-modal-file {
      width: 100%; padding: 8px 10px; font-size: 0.875rem; font-family: inherit;
      border: 1px dashed #c5c5c5; border-radius: 6px; background: #fafafa;
    }
    .modal-body:has(.i18n-admin-modal-form) label:not(.i18n-modal-radio) { margin-bottom: 0; }
    .modal-body:has(.i18n-admin-modal-form) input[type="file"] { margin-bottom: 0; border: none; padding: 0; background: transparent; }
    .i18n-edit-details { text-align: left; max-width: 720px; margin-top: 16px; }
    .i18n-kv-panel {
      border: 1px solid #e8e8e8; border-radius: 6px; background: #fafafa; overflow: hidden;
    }
    .i18n-kv-grid {
      display: grid; grid-template-columns: minmax(100px, 160px) minmax(0, 1fr);
      gap: 0; align-items: stretch; max-width: 720px;
    }
    .i18n-kv-label {
      padding: 14px 16px 14px 12px; text-align: right; font-weight: 600; font-size: 0.875rem;
      color: #505050; background: #f5f5f5; border-bottom: 1px solid #e8e8e8;
      display: flex; align-items: center; justify-content: flex-end;
    }
    .i18n-kv-value {
      padding: 14px 16px; text-align: left; font-size: 0.875rem; color: #303030;
      border-bottom: 1px solid #e8e8e8; min-width: 0; display: flex; align-items: center;
    }
    .i18n-kv-grid > .i18n-kv-label:nth-last-child(2),
    .i18n-kv-grid > .i18n-kv-value:last-child { border-bottom: none; }
    .i18n-kv-readonly { margin: 0; word-break: break-word; line-height: 1.45; }
    .i18n-edit-translation-section {
      margin-top: 20px; padding-top: 4px; max-width: 720px;
    }
    .i18n-edit-translation-label {
      display: block; font-weight: 600; font-size: 0.875rem; color: #505050; margin: 0 0 8px;
    }
    .i18n-edit-translation-section textarea {
      display: block; width: 100%; box-sizing: border-box; padding: 10px 12px;
      font-size: 0.875rem; font-family: inherit; border: 1px solid #c5c5c5; border-radius: 6px;
      min-height: 120px; resize: vertical;
    }
    .i18n-edit-translation-section textarea:focus {
      outline: none; border-color: #eb5202; box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.2);
    }
    .status-badge-unknown { background:#f5f5f5; color:#616161; border:1px solid #e0e0e0; }
    .status-badge-customer-new { background:#e3f2fd; color:#1565c0; border:1px solid #90caf9; }
    .status-badge-customer-active { background:#e8f5e9; color:#2e7d32; border:1px solid #a5d6a7; }
    .status-badge-customer-blocked { background:#ffebee; color:#b71c1c; border:1px solid #ef9a9a; }
    .status-badge-contact-new { background:#e3f2fd; color:#1565c0; border:1px solid #90caf9; }
    .status-badge-contact-viewed { background:#fff8e1; color:#8d6e00; border:1px solid #ffe082; }
    .status-badge-contact-replied { background:#e8f5e9; color:#2e7d32; border:1px solid #a5d6a7; }
  
/* core/forms */
/* Shared admin two-column forms (core/forms). Label right, control left. */

.admin-form {
  max-width: 800px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.admin-form__field {
  display: grid;
  grid-template-columns: minmax(160px, 240px) minmax(0, 1fr);
  gap: 8px 28px;
  align-items: center;
}

.admin-form__field--top {
  align-items: start;
}

.admin-form__field--full {
  display: block;
}

.admin-form__field--full .admin-form__control {
  max-width: none;
}

.admin-form__label-col {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  text-align: right;
}

.admin-form__label {
  margin: 0;
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.35;
  color: #303030;
}

.admin-form__field > .admin-form__label {
  justify-self: end;
  text-align: right;
  padding-right: 4px;
}

.admin-form__field--top > .admin-form__label {
  padding-top: 9px;
}

.admin-form__field--top .admin-form__label-col {
  padding-top: 9px;
}

.admin-form__hint {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.4;
  font-weight: 400;
  color: #6b7280;
  max-width: 220px;
}

.admin-form__control {
  min-width: 0;
  justify-self: start;
  width: 100%;
  max-width: 480px;
}

/* Inputs & selects */
.admin-form__control .admin-form__input,
.admin-form__control > input:not([type="hidden"]),
.admin-form__control .admin-form__input-row > input,
.admin-form__control > select,
.admin-form__control .admin-form__input-row > select,
.admin-form__control > textarea {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 9px 12px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #1a1a1a;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.admin-form__control > select,
.admin-form__control .admin-form__input-row > select {
  padding-right: 36px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23555' d='M2.5 4.5 6 8l3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px 12px;
}

.admin-form__control > input:not([type="hidden"]):hover,
.admin-form__control .admin-form__input-row > input:hover,
.admin-form__control > select:hover,
.admin-form__control .admin-form__input-row > select:hover,
.admin-form__control > textarea:hover {
  border-color: #9ca3af;
}

.admin-form__control > input:not([type="hidden"]):focus,
.admin-form__control .admin-form__input-row > input:focus,
.admin-form__control > select:focus,
.admin-form__control .admin-form__input-row > select:focus,
.admin-form__control > textarea:focus {
  outline: none;
  border-color: #1976d2;
  box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.15);
}

.admin-form__control > input[type="number"] {
  max-width: 140px;
}

.admin-form__control > textarea {
  min-height: 72px;
  resize: vertical;
}

/* Inline input + trailing preview (e.g. catalog icon) */
.admin-form__input-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 100%;
}

.admin-form__input-row > input,
.admin-form__input-row > select {
  flex: 1 1 200px;
  min-width: 0;
  max-width: 100%;
}

.admin-form__icon-preview {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: 36px;
  min-width: 36px;
  padding: 4px;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  background: #f9fafb;
}

.admin-form__icon-preview:empty {
  display: none;
}

.admin-form__icon-preview img,
.admin-form__icon-preview svg {
  display: block;
  max-width: 32px;
  max-height: 32px;
}

.admin-form__control .btn-row {
  margin-top: 8px;
}

/* Status select: green = Enabled, red = Disabled */
.admin-form__control > select.admin-form__status-select {
  font-weight: 600;
  max-width: 200px;
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--enabled {
  color: #1b5e20;
  background-color: #e8f5e9;
  border-color: #81c784;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231b5e20' d='M2.5 4.5 6 8l3.5-3.5'/%3E%3C/svg%3E");
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--disabled {
  color: #b71c1c;
  background-color: #ffebee;
  border-color: #ef9a9a;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23b71c1c' d='M2.5 4.5 6 8l3.5-3.5'/%3E%3C/svg%3E");
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--enabled:hover {
  border-color: #66bb6a;
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--disabled:hover {
  border-color: #e57373;
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--enabled:focus {
  border-color: #43a047;
  box-shadow: 0 0 0 3px rgba(67, 160, 71, 0.2);
}

.admin-form__control > select.admin-form__status-select.admin-form__status-select--disabled:focus {
  border-color: #e53935;
  box-shadow: 0 0 0 3px rgba(229, 57, 53, 0.2);
}

@media (max-width: 640px) {
  .admin-form__field {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .admin-form__label-col {
    align-items: flex-start;
    text-align: left;
  }

  .admin-form__hint {
    max-width: none;
  }

  .admin-form__field--top .admin-form__label-col {
    padding-top: 0;
  }
}

/* Inputs in detail tab panes (stacks without full .admin-form markup) */
.admin-detail-tab-panes input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
.admin-detail-tab-panes select,
.admin-detail-tab-panes textarea,
.tab-submenu-panes.admin-detail-tab-panes input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
.tab-submenu-panes.admin-detail-tab-panes select,
.tab-submenu-panes.admin-detail-tab-panes textarea {
  display: block;
  width: 100%;
  max-width: 480px;
  box-sizing: border-box;
  margin: 0 0 12px;
  padding: 9px 12px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #1a1a1a;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.admin-detail-tab-panes select,
.tab-submenu-panes.admin-detail-tab-panes select {
  padding-right: 36px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23555' d='M2.5 4.5 6 8l3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px 12px;
}

.admin-detail-tab-panes input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):focus,
.admin-detail-tab-panes select:focus,
.admin-detail-tab-panes textarea:focus,
.tab-submenu-panes.admin-detail-tab-panes input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):focus,
.tab-submenu-panes.admin-detail-tab-panes select:focus,
.tab-submenu-panes.admin-detail-tab-panes textarea:focus {
  outline: none;
  border-color: #1976d2;
  box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.15);
}

.admin-detail-tab-panes > label,
.admin-detail-tab-panes .exercise-edit-stack > label,
.tab-submenu-panes.admin-detail-tab-panes > label,
.tab-submenu-panes.admin-detail-tab-panes .exercise-edit-stack > label {
  display: block;
  margin: 0 0 6px;
  font-weight: 600;
  font-size: 0.875rem;
  color: #303030;
}

.admin-detail-tab-panes .exercise-edit-stack,
.tab-submenu-panes.admin-detail-tab-panes .exercise-edit-stack {
  max-width: 760px;
}

.eq-steps-editor-intro {
  display: block;
  width: 100%;
  max-width: none;
  margin: 0 0 12px;
  line-height: 1.5;
}

.admin-detail-tab-panes .eq-steps-editor-stack,
.tab-submenu-panes.admin-detail-tab-panes .eq-steps-editor-stack {
  max-width: none;
  width: 100%;
}

.eq-steps-editor-footer {
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
}

#exercise-edit-pane-steps,
#exercise-edit-steps-editor-wrap {
  max-width: none;
  width: 100%;
}

.exercise-edit-pane-steps .ex-steps-source-bar,
.exercise-edit-pane-steps .eq-steps-editor-intro {
  max-width: none;
  width: 100%;
}

.ex-steps-source-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  margin-bottom: 16px;
  padding: 12px 14px;
  background: #fafafa;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
}

.ex-steps-source-bar__label {
  font-weight: 600;
  font-size: 0.9rem;
  margin: 0;
}

.ex-steps-source-select {
  min-width: 280px;
  max-width: 100%;
}

.search-picker-wrap .ex-muscle-picker-purpose {
  display: block;
  width: 100%;
  min-width: 0;
  margin-bottom: 6px;
}

.ex-steps-source-bar .ex-steps-clear-all-btn {
  margin-left: auto;
}

.ex-steps-equipment-modal-intro {
  margin: 0 0 12px;
  line-height: 1.5;
}

.ex-steps-equipment-modal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0 0 12px;
}

.ex-steps-equipment-modal-field label {
  font-weight: 600;
  font-size: 0.875rem;
}

.ex-steps-equipment-modal-select {
  display: block;
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 9px 36px 9px 12px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #1a1a1a;
  background-color: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23555' d='M2.5 4.5 6 8l3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px 12px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ex-steps-equipment-modal-select:hover {
  border-color: #9ca3af;
}

.ex-steps-equipment-modal-select:focus {
  outline: none;
  border-color: #1976d2;
  box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.15);
}

.ex-steps-equipment-modal-single {
  margin: 0 0 12px;
  font-size: 0.9rem;
}

#ex-steps-editor-stack.ex-steps-editor--readonly .eq-step-card__title-input,
#ex-steps-editor-stack.ex-steps-editor--readonly .eq-step-description {
  cursor: not-allowed;
}

#exercise-edit-pane-muscles,
.exercise-edit-pane-muscles .ex-muscles-source-bar,
.exercise-edit-pane-muscles .ex-muscles-editor-intro {
  max-width: none;
  width: 100%;
}

#exercise-edit-muscles-body.ex-muscles-editor--readonly .search-picker-wrap {
  display: none;
}

.eq-equipment-images-form.ex-media-images--readonly .eq-step-browse-btn {
  pointer-events: none;
  opacity: 0.65;
}

.eq-step-browse-btn--with-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 112px;
  color: var(--redo-icon-color, #eb5202);
  border-color: rgba(235, 82, 2, 0.35);
  background: #fff;
}

.eq-step-browse-btn--with-icon:hover,
.eq-step-browse-btn--with-icon:focus-visible {
  border-color: var(--redo-icon-color, #eb5202);
  background: #fffaf5;
  color: var(--redo-icon-color, #eb5202);
  outline: none;
  box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.12);
}

.eq-step-browse-btn__icon {
  flex: 0 0 auto;
  display: block;
}

.eq-equipment-images-form .eq-step-browse-btn--icon-only {
  box-sizing: border-box;
  min-width: 0;
  width: 36px;
  height: 36px;
  padding: 0;
  gap: 0;
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ex-exercise-media-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ex-exercise-steps-media-section {
  margin-top: 24px;
}

.ex-exercise-steps-media-empty {
  margin: 0;
}

.ex-exercise-media-card--steps .ex-exercise-media-card__sort {
  justify-content: center;
}

.ex-exercise-steps-media__title {
  display: block;
  min-width: 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: #111827;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ex-exercise-media-slot-meta--steps {
  grid-template-rows: auto auto auto;
}

.ex-exercise-media-slot-meta--steps .ex-exercise-steps-media__title {
  grid-column: 1 / -1;
  grid-row: 1;
}

.ex-exercise-media-slot-meta--steps .ex-exercise-steps-media__default {
  grid-column: 1;
  grid-row: 2;
}

.ex-exercise-media-slot-meta--steps .ex-exercise-steps-media__all-genders {
  grid-column: 2;
  grid-row: 2;
  justify-self: start;
  min-width: 0;
}

.ex-exercise-media-slot-meta--steps .ex-exercise-steps-media__type {
  grid-column: 1;
  grid-row: 3;
  justify-self: stretch;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}

.eq-equipment-images-form select.ex-exercise-media-toolbar-select.ex-exercise-steps-media__type {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 3px 20px 3px 8px;
  font-size: 0.75rem;
  box-sizing: border-box;
}

.ex-exercise-media-slot-meta--steps .ex-exercise-steps-media__enabled {
  grid-column: 2;
  grid-row: 3;
  justify-self: start;
  min-width: 0;
}

.ex-exercise-media-card {
  position: relative;
}

.ex-exercise-media-card__layout {
  display: flex;
  align-items: stretch;
  max-width: none;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(17, 24, 39, 0.04);
  overflow: hidden;
}

.ex-exercise-media-card__sort {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  min-width: 4.75rem;
  padding: 14px 10px;
  border-right: 1px solid #e5e7eb;
  background: #f9fafb;
  user-select: none;
}

.ex-exercise-media-card__drag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  color: #9ca3af;
  font-size: 1.125rem;
  line-height: 1;
  cursor: grab;
}

.ex-exercise-media-card__drag[draggable="false"] {
  cursor: default;
  opacity: 0.35;
}

.ex-exercise-media-card--dragging .ex-exercise-media-card__drag {
  cursor: grabbing;
}

.ex-exercise-media-card__config {
  flex: 0 0 20rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 20rem;
  max-width: 24rem;
  padding: 14px 18px;
  border-right: 1px solid #e5e7eb;
  background: #fff;
}

.ex-exercise-media-card__media {
  flex: 1 1 auto;
  min-width: 0;
  padding: 14px 40px 14px 16px;
}

.ex-exercise-media-card--dragging {
  opacity: 0.55;
}

.ex-exercise-media-card__remove {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  margin: 0;
  padding: 0;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #fff;
  color: #9ca3af;
  cursor: pointer;
  transition: color 0.12s ease, border-color 0.12s ease, background 0.12s ease, box-shadow 0.12s ease;
}

.ex-exercise-media-card__remove:hover,
.ex-exercise-media-card__remove:focus-visible {
  color: #dc2626;
  border-color: #fecaca;
  background: #fef2f2;
  outline: none;
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.12);
}

.ex-exercise-media-card__remove svg {
  display: block;
}

.ex-exercise-media-card--readonly {
  opacity: 0.78;
}

.ex-exercise-media-card--readonly .ex-exercise-media-card__config {
  background: #fafafa;
}

.ex-exercise-media-card--readonly .ex-exercise-media-card__media {
  background: #fcfcfc;
}

.ex-exercise-media-card--readonly .eq-step-browse-btn {
  pointer-events: none;
  opacity: 0.55;
}

.ex-exercise-media-card--readonly .ex-cache-preview-trigger,
.ex-exercise-media-card--readonly .ex-cache-preview-slot img {
  filter: grayscale(0.9);
  opacity: 0.75;
}

.ex-exercise-media-card--readonly .ex-exercise-media-video-filename {
  color: #9ca3af;
}

.ex-exercise-media-add-wrap {
  margin-top: 14px;
}

.ex-exercise-media-add-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 20px;
  border: 1.5px dashed rgba(235, 82, 2, 0.45);
  border-radius: 10px;
  background: linear-gradient(180deg, #fffaf5 0%, #fff 100%);
  color: var(--redo-icon-color, #eb5202);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.ex-exercise-media-add-btn:hover,
.ex-exercise-media-add-btn:focus-visible {
  border-style: solid;
  border-color: var(--redo-icon-color, #eb5202);
  background: #fff5eb;
  box-shadow: 0 4px 14px rgba(235, 82, 2, 0.14);
  outline: none;
  transform: translateY(-1px);
}

.ex-exercise-media-add-btn__icon {
  display: block;
  flex: 0 0 auto;
}

.ex-exercise-media-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px;
}

.ex-exercise-media-toolbar-field {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ex-exercise-media-toolbar-field__label {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #374151;
  white-space: nowrap;
}

.eq-equipment-images-form .ex-exercise-media-toolbar-select {
  width: auto !important;
  min-width: 9.5rem;
  max-width: none !important;
  margin: 0 !important;
  padding: 4px 28px 4px 10px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #374151;
  border: 1px solid #c2c2c2;
  border-radius: 6px;
  background-color: #fff;
  cursor: pointer;
}

.eq-equipment-images-form .ex-exercise-media-toolbar-select:focus {
  border-color: var(--redo-icon-color, #eb5202);
  outline: none;
  box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.12);
}

.ex-exercise-media-video-placeholder {
  margin: 0;
  padding: 12px 0 4px;
  font-size: 0.875rem;
  color: #64748b;
}

.eq-equipment-images-form .ex-exercise-media-toolbar label {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin: 0 !important;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #374151;
  cursor: pointer;
  user-select: none;
}

.ex-exercise-media-option--static {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #374151;
  user-select: none;
}

.ex-exercise-media-option__icon--on {
  color: var(--redo-icon-color, #eb5202);
}

.ex-exercise-media-option__cb {
  appearance: none;
  -webkit-appearance: none;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  flex: 0 0 16px;
  border: 1px solid #adadad;
  border-radius: 3px;
  background: #fff;
  cursor: pointer;
  position: relative;
}

.ex-exercise-media-option__cb:hover {
  border-color: #666;
}

.ex-exercise-media-option__cb:checked {
  background: var(--redo-icon-color, #eb5202);
  border-color: var(--redo-icon-color, #eb5202);
}

.ex-exercise-media-option__cb:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.ex-exercise-media-option__icon {
  flex: 0 0 auto;
  display: block;
  color: #9ca3af;
  transition: color 0.12s ease;
}

.ex-exercise-media-option__cb:checked ~ .ex-exercise-media-option__icon {
  color: var(--redo-icon-color, #eb5202);
}

.ex-exercise-media-option__label {
  line-height: 1.2;
}

.ex-exercise-media-slot-meta {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 12px 20px;
  align-items: center;
  min-width: 0;
  width: 100%;
}

.ex-exercise-media-slot-meta__row {
  display: contents;
}

.ex-exercise-media-slot-meta__default {
  grid-column: 1;
  grid-row: 1;
}

.ex-exercise-media-slot-meta__all-genders {
  grid-column: 2;
  grid-row: 1;
}

.ex-exercise-media-slot-meta__type {
  grid-column: 1;
  grid-row: 2;
  justify-self: stretch;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}

.eq-equipment-images-form select.ex-exercise-media-toolbar-select.ex-exercise-media-slot-meta__type {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 3px 20px 3px 8px;
  font-size: 0.75rem;
  box-sizing: border-box;
}

.ex-exercise-media-slot-meta__enabled {
  grid-column: 2;
  grid-row: 2;
  justify-self: start;
  min-width: 0;
}

.ex-exercise-media-position-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  padding: 4px 9px;
  border-radius: 6px;
  background: #fff5eb;
  border: 1px solid rgba(235, 82, 2, 0.35);
  color: var(--redo-icon-color, #eb5202);
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  user-select: none;
}

.ex-exercise-media-option--plain {
  gap: 8px;
}

.eq-equipment-images-form .ex-exercise-media-option--plain {
  display: inline-flex !important;
  align-items: center;
}

.eq-equipment-images-form .ex-exercise-media-default-radio {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin: 0 !important;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #374151;
  cursor: pointer;
  user-select: none;
}

.ex-exercise-media-option__rb {
  appearance: none;
  -webkit-appearance: none;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  flex: 0 0 16px;
  border: 1px solid #adadad;
  border-radius: 50%;
  background: #fff;
  cursor: pointer;
  position: relative;
}

.ex-exercise-media-option__rb:hover {
  border-color: #666;
}

.ex-exercise-media-option__rb:checked {
  border-color: var(--redo-icon-color, #eb5202);
}

.ex-exercise-media-option__rb:checked::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 8px;
  height: 8px;
  margin: -4px 0 0 -4px;
  border-radius: 50%;
  background: var(--redo-icon-color, #eb5202);
}

.ex-exercise-media-content {
  min-width: 0;
}

.ex-exercise-media-video-panel {
  min-width: 0;
}

.ex-exercise-media-video-row .eq-step-image-row__assets {
  flex-wrap: wrap;
  align-items: center;
}

.ex-exercise-media-video-filename {
  flex: 1 1 8rem;
  min-width: 0;
  max-width: 18rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #1f2937;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ex-exercise-media-video-filename--empty {
  color: #94a3b8;
  font-weight: 400;
}

.ex-exercise-media-genders {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px 24px;
  min-width: 0;
}

.ex-exercise-media-card__media .ex-exercise-media-genders {
  gap: 16px 28px;
}

.ex-exercise-media-card__media .eq-step-image-row {
  flex-direction: row;
  align-items: center;
  gap: 10px;
  margin-bottom: 0;
}

.ex-exercise-media-card__media .eq-step-image-row__sex {
  flex: 0 0 3.5rem;
  min-width: 3.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: none;
  letter-spacing: normal;
  color: #374151;
}

.ex-exercise-media-card__media .eq-step-image-row__assets {
  flex: 1 1 auto;
  width: auto;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
}

.ex-exercise-media-card__media .ex-cache-preview-slot {
  flex: 0 0 80px;
  width: 80px;
  height: 80px;
}

.ex-exercise-media-card__media .ex-cache-preview-trigger {
  width: 80px;
  height: 80px;
  border-radius: 8px;
}

.ex-exercise-media-card__media .ex-cache-preview-trigger img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ex-exercise-media-card__media .ex-cache-preview-slot .catalog-image-preview-empty {
  width: 80px;
  height: 80px;
  border-radius: 8px;
  font-size: 0.6875rem;
}

.ex-exercise-media-genders--single {
  grid-template-columns: minmax(0, 1fr);
}

.ex-exercise-media-column {
  min-width: 0;
}

.ex-exercise-media-column__title {
  margin: 0 0 12px;
  font-size: 0.95rem;
  font-weight: 600;
  color: #1f2937;
}

.ex-exercise-media-column .eq-equipment-images-list {
  margin: 0;
}

.ex-exercise-media-column .eq-step-image-row__assets {
  gap: 12px;
}

.ex-cache-preview-slot {
  position: relative;
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
}

.ex-cache-preview-trigger {
  display: block;
  width: 56px;
  height: 56px;
  margin: 0;
  padding: 0;
  border: 1px solid #c2c2c2;
  border-radius: 6px;
  background: #fff;
  cursor: pointer;
  overflow: hidden;
  box-sizing: border-box;
}

.ex-cache-preview-trigger:hover,
.ex-cache-preview-trigger:focus-visible {
  border-color: #eb5202;
  outline: none;
  box-shadow: 0 0 0 2px rgba(235, 82, 2, 0.15);
}

.ex-cache-preview-trigger.hidden {
  display: none;
}

.ex-cache-preview-trigger img {
  display: block;
  width: 56px;
  height: 56px;
  object-fit: cover;
}

.ex-video-preview-trigger.hidden {
  display: none;
}

.ex-video-preview-trigger:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.ex-exercise-media-card--readonly .ex-video-preview-trigger {
  pointer-events: none;
  opacity: 0.45;
}

.ex-cache-preview-slot .catalog-image-preview-empty {
  width: 56px;
  height: 56px;
  margin: 0;
}

.ex-cache-size-menu {
  position: fixed;
  z-index: 12050;
  min-width: 132px;
  padding: 4px 0;
  border: 1px solid #c2c2c2;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(17, 24, 39, 0.14);
}

.ex-cache-size-menu.hidden {
  display: none;
}

.ex-cache-size-menu__item {
  display: block;
  width: 100%;
  margin: 0;
  padding: 8px 14px;
  border: 0;
  background: transparent;
  color: #1f2937;
  font-size: 0.875rem;
  text-align: left;
  cursor: pointer;
}

.ex-cache-size-menu__item:hover,
.ex-cache-size-menu__item:focus-visible {
  background: #f3f4f6;
  outline: none;
}

.exercise-edit-pane-muscles .ex-muscles-source-bar .ex-muscles-clear-all-btn.hidden {
  display: none;
}

.eq-steps-list {
  display: grid;
  gap: 16px;
}

.eq-step-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 24px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 16px 18px;
  background: #fafafa;
  width: 100%;
}

.eq-step-card__left,
.eq-step-card__right {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.eq-step-card__left {
  grid-column: 1;
}

.eq-step-card__right {
  grid-column: 2;
}

.eq-step-card__head-main {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-width: 0;
  line-height: 1.25;
}

.eq-step-card__number {
  flex: 0 0 auto;
  white-space: nowrap;
  margin: 0;
  line-height: 1.25;
  font-size: 0.875rem;
}

.eq-step-card__title-label {
  flex: 0 0 auto;
  margin: 0;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1.25;
  font-size: 0.875rem;
}

.admin-detail-tab-panes .eq-step-card__title-input,
.tab-submenu-panes.admin-detail-tab-panes .eq-step-card__title-input {
  flex: 1 1 0;
  width: auto;
  min-width: 0;
  max-width: none;
  display: block;
  margin: 0;
  padding: 4px 10px;
  height: 2rem;
  line-height: 1.25;
  font-size: 0.875rem;
  align-self: center;
}

.eq-step-card__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  min-height: 2rem;
}

.eq-step-card__col--description,
.eq-step-card__col--images {
  display: flex;
  flex-direction: column;
  min-height: 0;
  width: 100%;
}

.admin-detail-tab-panes .eq-step-card__col--description .eq-step-description,
.tab-submenu-panes.admin-detail-tab-panes .eq-step-card__col--description .eq-step-description {
  max-width: none;
  width: 100%;
  margin-bottom: 0;
}

.eq-step-card__col--description label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  flex: 0 0 auto;
}

.eq-step-card__col--description .eq-step-description {
  display: block;
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  resize: none;
  box-sizing: border-box;
}

.eq-step-card__col--images .eq-step-images-heading {
  flex: 0 0 auto;
}

.eq-step-images-heading {
  margin: 0 0 10px;
  font-size: 0.95rem;
  font-weight: 600;
}

.eq-step-images-hint {
  margin: 0 0 10px;
  font-size: 0.85rem;
  line-height: 1.4;
}

.eq-step-image-row--preview-only .eq-step-image-row__assets {
  flex: 0 1 auto;
}

.eq-step-image-row--preview-only .eq-step-browse-btn,
.eq-step-image-row--preview-only .eq-step-image-row__path {
  display: none !important;
}

.eq-step-image-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.eq-step-image-row__sex {
  flex: 0 0 3.5rem;
  font-weight: 600;
  font-size: 0.875rem;
  color: #374151;
}

.eq-step-image-row__assets {
  display: flex;
  flex: 1;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.eq-step-image-row__assets .catalog-image-preview,
.eq-step-image-row__assets .catalog-image-preview-empty {
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
  margin: 0;
  box-sizing: border-box;
}

.eq-step-image-row__assets .catalog-image-preview img {
  width: 56px;
  height: 56px;
  object-fit: cover;
}

.eq-step-browse-btn {
  flex: 0 0 auto;
  height: 56px;
  margin: 0;
  padding: 0 16px;
  cursor: pointer;
  border: 1px solid #adadad;
  border-radius: 6px;
  background: linear-gradient(180deg, #ffffff 0%, #f3f4f6 100%);
  color: #1f2937;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  box-sizing: border-box;
}

.eq-step-browse-btn:hover {
  border-color: #007bdb;
  background: linear-gradient(180deg, #f8fbff 0%, #e8f2fc 100%);
  color: #005a9e;
}

.eq-step-browse-btn:active {
  background: #e5e7eb;
}

.eq-step-image-row__path {
  flex: 0 1 auto;
  width: min(100%, 10rem);
  max-width: 10rem;
  height: 56px;
  margin: 0;
  padding: 0 10px;
  box-sizing: border-box;
}

.eq-equipment-content-columns,
.eq-equipment-information-columns {
  max-width: none;
  width: 100%;
}

.equipment-information-primary,
.equipment-information-facets {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.eq-scoring-fields {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 10px;
  row-gap: 2px;
  align-items: center;
  max-width: 300px;
}

.eq-scoring-fields__intro {
  grid-column: 1 / -1;
  margin: 0 0 4px;
}

.eq-scoring-row {
  display: contents;
}

.eq-scoring-row label {
  margin: 0;
  font-weight: 600;
}

.eq-scoring-fields .eq-scoring-input {
  width: 2.5rem;
  min-width: 2.5rem;
  max-width: 2.5rem;
  box-sizing: border-box;
  margin: 0;
  padding: 2px;
  text-align: center;
  -moz-appearance: textfield;
}

.eq-scoring-fields .eq-scoring-input::-webkit-outer-spin-button,
.eq-scoring-fields .eq-scoring-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.eq-equipment-content-column-heading {
  margin: 0 0 12px;
  font-size: 1rem;
  font-weight: 600;
}

.eq-equipment-images-form {
  max-width: 960px;
}

.eq-equipment-media-section-heading {
  margin: 0 0 12px;
  font-size: 1rem;
  font-weight: 600;
}

.eq-equipment-media-divider {
  margin: 20px 0;
  border: 0;
  border-top: 1px solid #d1d1d1;
}

.eq-equipment-media-placeholder {
  margin: 0;
  color: #666;
  font-size: 0.9375rem;
  line-height: 1.45;
}

.catalog-fill-ring-td {
  width: 52px;
  text-align: center;
  vertical-align: middle;
}

.catalog-fill-ring {
  --catalog-fill-ring-size: 40px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--catalog-fill-ring-size);
  height: var(--catalog-fill-ring-size);
}

.catalog-fill-ring__svg {
  display: block;
}

.catalog-fill-ring__track {
  stroke: #e5e7eb;
}

.catalog-fill-ring__progress {
  stroke-linecap: round;
  transition: stroke-dashoffset 0.2s ease;
}

.catalog-fill-ring--full .catalog-fill-ring__progress {
  stroke: #16a34a;
}

.catalog-fill-ring--mid .catalog-fill-ring__progress {
  stroke: #ea580c;
}

.catalog-fill-ring--low .catalog-fill-ring__progress {
  stroke: #dc2626;
}

.catalog-fill-ring__label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1;
  color: #111827;
  pointer-events: none;
}

.catalog-fill-ring--full .catalog-fill-ring__label {
  color: #15803d;
}

.catalog-fill-ring--mid .catalog-fill-ring__label {
  color: #c2410c;
}

.catalog-fill-ring--low .catalog-fill-ring__label {
  color: #b91c1c;
}

.eq-equipment-images-form__intro {
  margin: 0 0 12px;
  max-width: none;
  color: #303030;
  font-size: 1rem;
  line-height: 1.5;
}

.eq-equipment-images-form__intro-label {
  margin: 0 0 4px;
}

.eq-equipment-images-form__path {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.45;
}

.eq-equipment-images-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.eq-equipment-image-row .eq-step-image-row__sex {
  flex: 0 0 4.25rem;
}

.eq-equipment-image-row .eq-step-image-row__path {
  flex: 1 1 auto;
  width: auto;
  max-width: none;
  min-width: 0;
}


.eq-mistakes-list {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}

.eq-mistake-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.eq-mistake-row input {
  flex: 1;
}

.exercise-edit-info-columns--triple {
  margin-top: 28px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1200px) {
  .exercise-edit-info-columns--triple {
    grid-template-columns: 1fr;
  }
}

.ex-content-coaching-intro {
  margin: 0 0 12px;
  font-size: 0.85rem;
}

.ex-content-coaching-empty {
  margin: 0;
  font-size: 0.85rem;
}

.ex-content-step-fields-list {
  display: grid;
  gap: 12px;
}

.ex-content-step-block label {
  display: block;
  margin: 0 0 4px;
  font-size: 0.8125rem;
  font-weight: 600;
}

.ex-content-step-block textarea {
  width: 100%;
  box-sizing: border-box;
}

.ex-content-field-hint {
  margin: 0 0 8px;
  font-size: 0.8125rem;
  line-height: 1.45;
}

.ex-content-field-hint code {
  font-size: 0.78rem;
}

.ex-content-field-hint--footer {
  margin-top: 20px;
}

.ex-content-mistakes-list {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
}

.ex-content-mistake-block {
  display: grid;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #fafafa;
}

.ex-content-mistake-block__head {
  display: flex;
  gap: 8px;
  align-items: center;
}

.ex-content-mistake-step-label {
  font-size: 0.8125rem;
  font-weight: 600;
  white-space: nowrap;
}

.ex-content-mistake-step {
  flex: 1;
  min-width: 0;
}

.ex-content-mistake-block input,
.ex-content-mistake-block textarea {
  width: 100%;
  box-sizing: border-box;
}

.eq-name-aliases-block {
  margin: 4px 0 12px;
}

.eq-name-aliases-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

.eq-name-aliases-label {
  font-weight: 600;
  font-size: 0.875rem;
}

.eq-name-aliases-list {
  display: grid;
  gap: 10px;
}

.eq-alias-row {
  display: flex;
  gap: 10px;
  align-items: flex-end;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #fafafa;
}

.eq-alias-row__fields {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;
  flex: 1;
}

.eq-alias-row__label {
  display: grid;
  gap: 4px;
  font-size: 0.8125rem;
  font-weight: 600;
}

.eq-alias-row__label input {
  width: 100%;
}

.equipment-assignments-pane {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.equipment-assignments-section {
  padding-bottom: 4px;
  border-bottom: 1px solid #e5e7eb;
}

.equipment-assignments-section:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.equipment-assignments-section__title {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 600;
  color: #303030;
}

.equipment-assignments-section__deprecated {
  margin-left: 8px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #ea580c;
}

/* System → Import / Export catalog forms */
.catalog-import-export-form {
  max-width: 720px;
  margin-top: 8px;
}

.catalog-import-export-form .admin-form__control > select {
  min-width: 240px;
  max-width: 360px;
}

.catalog-import-export-form__control-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 16px;
}

.catalog-import-export-form__control-row > select {
  flex: 0 1 auto;
}

.catalog-import-export-form .admin-form__control > input[type="file"] {
  display: block;
  width: 100%;
  max-width: 360px;
  padding: 8px 10px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #303030;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
  cursor: pointer;
}

.catalog-import-export-form .admin-form__control > input[type="file"]:hover {
  border-color: #9ca3af;
}

.catalog-import-export-form .admin-form__control > input[type="file"]:focus {
  outline: none;
  border-color: #1976d2;
  box-shadow: 0 0 0 3px rgba(25, 118, 210, 0.15);
}

.catalog-import-export-form .admin-form__control > input[type="text"] {
  display: block;
  width: 100%;
  max-width: 360px;
  padding: 8px 10px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #303030;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
}

/* core/forms detail nav */
/* Magento-style vertical detail tabs (default for .tab-submenu-layout). */

.tab-submenu-layout.admin-detail-layout {
  align-items: stretch;
  gap: 0;
  margin-top: 12px;
  border: 1px solid #d6d6d6;
  background: #f5f5f5;
}

.tab-submenu-layout.admin-detail-layout > .admin-detail-nav,
.tab-submenu-layout.admin-detail-layout > .exercise-edit-tabs {
  display: flex;
  flex-direction: column;
  width: 240px;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
  min-width: 240px;
  border: none;
  border-right: 1px solid #d6d6d6;
  border-radius: 0;
  background: #f5f5f5;
  list-style: none;
}

.tab-submenu-layout.admin-detail-layout > .tab-submenu-panes,
.tab-submenu-layout.admin-detail-layout > .admin-detail-tab-panes {
  flex: 1;
  min-width: 0;
  padding: 20px 24px;
  background: #fff;
}

.admin-detail-nav__head {
  padding: 14px 16px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #303030;
  background: #ebebeb;
  border-bottom: 1px solid #d6d6d6;
}

.admin-detail-nav__item,
.tab-submenu-layout.admin-detail-layout > .admin-detail-nav > button[role="tab"],
.tab-submenu-layout.admin-detail-layout > .exercise-edit-tabs > button[role="tab"] {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  text-align: left;
  padding: 12px 16px 12px 18px;
  margin: 0;
  border: none;
  border-left: 4px solid transparent;
  border-radius: 0;
  background: transparent;
  color: #303030;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.35;
  cursor: pointer;
  font-family: inherit;
}

.admin-detail-nav__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #666;
  line-height: 0;
}

.admin-detail-nav__item.active .admin-detail-nav__icon,
.tab-submenu-layout.admin-detail-layout > .exercise-edit-tabs > button[role="tab"].active .admin-detail-nav__icon {
  color: #eb5202;
}

.admin-detail-nav__label {
  flex: 1;
  min-width: 0;
}

.admin-detail-nav__item:hover:not(.active),
.tab-submenu-layout.admin-detail-layout > .admin-detail-nav > button[role="tab"]:hover:not(.active),
.tab-submenu-layout.admin-detail-layout > .exercise-edit-tabs > button[role="tab"]:hover:not(.active) {
  background: rgba(255, 255, 255, 0.45);
}

.admin-detail-nav__item.active,
.tab-submenu-layout.admin-detail-layout > .admin-detail-nav > button[role="tab"].active,
.tab-submenu-layout.admin-detail-layout > .exercise-edit-tabs > button[role="tab"].active {
  background: #fff;
  border-left-color: #eb5202;
  color: #1a1a1a;
  font-weight: 700;
}

/* core/forms permission tree */
/* Permission tree — Magento-style Resources ACL */

.perm-res-tree {
  max-height: min(70vh, 640px);
  overflow: auto;
  border: 1px solid #d6d6d6;
  background: #fff;
  font-size: 0.875rem;
  line-height: 1.35;
}

.perm-res-tree-title {
  padding: 10px 12px;
  font-weight: 700;
  font-size: 0.9375rem;
  border-bottom: 1px solid #e3e3e3;
  background: #fafafa;
  color: #303030;
}

.perm-res-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.perm-res-list--root {
  padding: 4px 0 8px;
}

.perm-res-node--branch > .perm-res-list {
  display: block;
}

.perm-res-node--branch.perm-res-node--collapsed > .perm-res-list {
  display: none;
}

.perm-res-row {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 2px 12px 2px 0;
  cursor: default;
  user-select: none;
}

.perm-res-row:hover {
  background: #e8f4fc;
}

.perm-res-toggle {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  position: relative;
  color: #555;
}

.perm-res-toggle::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 4px;
  border: 5px solid transparent;
  border-left-color: currentColor;
  border-right: none;
  transition: transform 0.12s ease;
}

.perm-res-node--open > .perm-res-row > .perm-res-toggle::before {
  transform: rotate(90deg);
  top: 6px;
  left: 4px;
}

.perm-res-toggle--spacer {
  pointer-events: none;
  visibility: hidden;
}

.perm-res-tree label {
  display: contents !important;
  margin: 0 !important;
  padding: 0;
  font-weight: inherit;
  font-size: inherit;
}

.admin-detail-tab-panes .perm-res-tree label,
.tab-submenu-panes.admin-detail-tab-panes .perm-res-tree label {
  display: contents !important;
  margin: 0 !important;
}

.perm-res-cb {
  flex-shrink: 0;
  appearance: none;
  -webkit-appearance: none;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  border: 1px solid #adadad;
  border-radius: 2px;
  background: #fff;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
}

.perm-res-cb:hover {
  border-color: #666;
}

.perm-res-cb:checked {
  background: #0a7d3b;
  border-color: #0a7d3b;
}

.perm-res-cb:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.perm-res-cb:indeterminate,
.perm-res-cb[data-indeterminate="1"] {
  background: #fff;
  border-color: #0a7d3b;
}

.perm-res-cb:indeterminate::after,
.perm-res-cb[data-indeterminate="1"]::after {
  content: "";
  position: absolute;
  left: 3px;
  top: 6px;
  width: 8px;
  height: 2px;
  background: #0a7d3b;
  border: none;
  transform: none;
}

.perm-res-folder-icon {
  flex-shrink: 0;
  display: block;
}

.perm-res-label {
  flex: 1;
  min-width: 0;
  color: #303030;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.perm-res-node--leaf .perm-res-label {
  font-weight: 400;
}

.perm-res-node--branch > .perm-res-row > .perm-res-label {
  font-weight: 600;
}

.perm-res-node--all > .perm-res-row--all > .perm-res-label {
  font-weight: 700;
}

.perm-res-label .perm-res-code {
  font-size: 0.75rem;
  font-weight: 400;
  color: #888;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

/* admin/dashboard charts */
.dashboard-charts-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 8px;
}

@media (max-width: 1280px) {
  .dashboard-charts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .dashboard-charts-grid {
    grid-template-columns: 1fr;
  }
}

.dashboard-chart-card {
  background: #fff;
  border: 1px solid #d1d1d1;
  border-radius: 6px;
  padding: 14px 16px 12px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  min-height: 280px;
  display: flex;
  flex-direction: column;
}

.dashboard-chart-card--featured {
  grid-column: span 1;
}

.dashboard-chart-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px 12px;
  margin-bottom: 10px;
}

.dashboard-chart-card__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: #1a1a1a;
}

.dashboard-chart-card__subtitle {
  margin: 2px 0 0;
  font-size: 0.75rem;
  color: #666;
}

.dashboard-chart-card__meta {
  font-size: 0.75rem;
  color: #888;
  white-space: nowrap;
}

.dashboard-chart-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.dashboard-chart-filters label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.7rem;
  color: #666;
  font-weight: 500;
}

.dashboard-chart-filters input,
.dashboard-chart-filters select {
  font-size: 0.8rem;
  padding: 4px 8px;
  border: 1px solid #adadad;
  border-radius: 2px;
  min-width: 0;
}

.dashboard-chart-filters .btn-primary {
  padding: 6px 12px;
  font-size: 0.8rem;
  margin-top: 14px;
}

.dashboard-chart-canvas-wrap {
  position: relative;
  flex: 1;
  min-height: 200px;
}

.dashboard-chart-canvas-wrap canvas {
  width: 100% !important;
  height: 100% !important;
}

.dashboard-chart-demo-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #6b4e16;
  background: #fff3d6;
  border: 1px solid #f0d78c;
  border-radius: 3px;
  padding: 2px 6px;
}
