/* Temp styles until rmv is gone */
:root:not(:has(rmv-styles[appearance="dark"])):has(body) {
  --color-base-light: 255 255 255;
  --color-base-dark: 20 24 31;
  --color-base-balanced-100: 244 243 252;
  --color-base-balanced-200: 201 194 240;
  --color-base-balanced-300: 159 145 227;
  --color-base-balanced-400: 116 96 215;
  --color-base-balanced-500: 77 51 204;
  --color-base-balanced-600: 61 41 163;
  --color-base-balanced-700: 46 31 122;
  --color-base-balanced-800: 32 21 86;
  --color-base-balanced-900: 18 12 49;
  --color-base-brave-100: 245 246 250;
  --color-base-brave-200: 207 212 231;
  --color-base-brave-300: 127 144 184;
  --color-base-brave-400: 66 89 139;
  --color-base-brave-500: 0 34 112;
  --color-base-brave-600: 0 30 97;
  --color-base-brave-700: 0 25 82;
  --color-base-brave-800: 0 21 66;
  --color-base-brave-900: 0 16 51;
  --color-base-energized-100: 240 247 255;
  --color-base-energized-200: 178 217 255;
  --color-base-energized-300: 117 186 255;
  --color-base-energized-400: 56 156 255;
  --color-base-energized-500: 0 128 255;
  --color-base-energized-600: 0 101 204;
  --color-base-energized-700: 0 75 153;
  --color-base-energized-800: 0 75 153;
  --color-base-energized-900: 0 30 61;
  --color-base-fair-100: 244 251 251;
  --color-base-fair-200: 198 236 236;
  --color-base-fair-300: 152 221 221;
  --color-base-fair-400: 152 221 221;
  --color-base-fair-500: 64 191 191;
  --color-base-fair-600: 51 153 153;
  --color-base-fair-700: 38 115 115;
  --color-base-fair-800: 27 80 80;
  --color-base-fair-900: 15 46 46;
  --color-base-fluent-100: 253 241 246;
  --color-base-fluent-200: 247 186 211;
  --color-base-fluent-300: 247 186 211;
  --color-base-fluent-400: 235 76 142;
  --color-base-fluent-500: 233 0 97;
  --color-base-fluent-600: 204 0 85;
  --color-base-fluent-700: 153 0 64;
  --color-base-fluent-800: 107 0 45;
  --color-base-fluent-900: 61 0 26;
  --color-base-royal-100: 244 243 252;
  --color-base-royal-200: 201 194 240;
  --color-base-royal-300: 159 145 227;
  --color-base-royal-400: 116 96 215;
  --color-base-royal-500: 77 51 204;
  --color-base-royal-600: 61 41 163;
  --color-base-royal-700: 46 31 122;
  --color-base-royal-800: 32 21 86;
  --color-base-royal-900: 18 12 49;
  --color-state-assertive-100: 255 242 242;
  --color-state-assertive-200: 255 178 178;
  --color-state-assertive-300: 255 117 117;
  --color-state-assertive-400: 252 54 54;
  --color-state-assertive-500: 245 0 0;
  --color-state-assertive-600: 199 0 0;
  --color-state-assertive-700: 153 0 0;
  --color-state-assertive-800: 107 0 0;
  --color-state-assertive-900: 61 0 0;
  --color-state-mild-100: 255 247 238;
  --color-state-mild-200: 255 221 178;
  --color-state-mild-300: 255 186 102;
  --color-state-mild-400: 255 150 26;
  --color-state-mild-500: 209 115 0;
  --color-state-mild-600: 173 95 0;
  --color-state-mild-700: 138 75 0;
  --color-state-mild-800: 92 50 0;
  --color-state-mild-900: 61 33 0;
  --color-state-positive-100: 245 251 244;
  --color-state-positive-200: 205 236 198;
  --color-state-positive-300: 156 216 141;
  --color-state-positive-400: 106 197 83;
  --color-state-positive-500: 73 157 52;
  --color-state-positive-600: 61 130 44;
  --color-state-positive-700: 49 104 34;
  --color-state-positive-800: 38 80 27;
  --color-state-positive-900: 22 46 15;
  --color-grey-stable-100: 247 250 255;
  --color-grey-stable-200: 237 242 253;
  --color-grey-stable-300: 230 236 249;
  --color-grey-stable-400: 226 232 243;
  --color-grey-stable-500: 221 227 238;
  --color-grey-stable-600: 155 171 202;
  --color-grey-stable-700: 76 99 143;
  --color-grey-stable-800: 46 60 86;
  --color-grey-stable-900: 21 28 40;
  --font-family-heading: "Switzer Variable", sans-serif;
  --font-family-body: "Inter", sans-serif;
  --font-family-code: "Roboto Mono", monospace;

  --text-weight-regular: var(--font-weight-500);
  --text-weight-light: var(--font-weight-500);
}

[color="balanced-500"] {
  color: var(--text-secondary);
}

[color="stable-900"] {
  color: var(--text-secondary);
}

/* END temp styles until rmv is gone */


turbo-frame,
turbo-frame[busy],
turbo-frame[complete],
form[data-turbo="true"] {
  display: contents;
}

/* Custom styles for the ReMark BRMS application */
:root {
  --select-option-selected-background-color: rgba(var(--color-balanced-300), 1);
  --select-option-focused-background-color: rgba(var(--color-balanced-300), 1);
  --table-tbody-tr-coloredRow-background: rgba(var(--color-light), 1);
  --table-tbody-tr-coloredRow-border-left: none;
}

.hidden,
:not(:defined) {
  display: none;
}

.invisible {
  visibility: hidden;
}

.widget-wrapper {
  margin: 0 auto;
  padding: 0 36px;
  width: 100%;
  height: calc(100vh - 121px);
  overflow-y: auto;
}

.widget-wrapper rmv-widget {
  max-width: 760px;
}

.widget-read-only rmv-widget::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  z-index: 10;
}

/* Debugger sidebar is 480px (360px until xxl screens) */
.debugger-sidebar {
  height: calc(100vh - 121px);
  display: flex;
  position: sticky;
  top: 121px;
}

@media (max-width: 1440px) {
  .debugger-sidebar {
    max-width: 360px;
  }
}

.widget-wrapper.test-case-input,
.widget-wrapper.test-case-session {
  height: auto;
  overflow-y: visible;
}

.widget-wrapper.session-debugger {
  height: calc(100vh - 167px);
  overflow-y: auto;
}

.debugger-sidebar.session-debugger {
  height: calc(100vh - 167px);
  top: 167px;
}

.session-debugger .debugger-sidebar {
  height: calc(100vh - 167px);
  top: 167px;
}

/* app/views/layouts/application.html.erb */
:root:has(rmv-styles[appearance="dark"]) .header {
  --row-background-color: rgb(var(--color-base-brave-200));
}

:root:has(rmv-styles[appearance="dark"]) .header rmv-action-trigger,
:root:has(rmv-styles[appearance="dark"]) .header rmv-action-trigger:hover {
  --button-color: rgb(var(--color-base-dark));
  --icon-color: rgb(var(--color-base-dark));
  --content-color: rgb(var(--color-base-dark));
}

:root:has(rmv-styles[appearance="dark"]) .header rmv-divider[variant="solid"]:not([height="1"]) {
  --divider-border-left: 1px solid rgb(var(--color-base-brave-100));
  --divider-opacity: 1;
}

:root:has(rmv-styles[appearance="dark"]) .header rmv-button[show-in="menu"]:not([disabled]) {
  --button-background-color: transparent;
  --icon-color: rgb(var(--color-base-dark));
  --content-color: rgb(var(--color-base-dark));
}

.header {
  --row-z-index: 2;
  --row-position: sticky;
  --row-box-shadow: var(--elevation-md);
  top: 0;
}

.header-divider {
  --divider-opacity: 0.2;
}

brms-explorer brms-input-search .brms-input .rm-input {
  --simple-height: 40px;
}

.rulesets {
  --color-base-brave-100: var(--color-base-royal-100);
  --color-base-brave-500: var(--color-base-royal-500);
  --color-base-brave-700: var(--color-base-royal-900);
  --color-base-energized-500: var(--color-base-royal-900);
}

.rulesets:hover {
  --icon-color: var(--color-base-royal-500);
}

.subsets {
  --color-base-brave-100: var(--color-base-fair-100);
  --color-base-brave-500: var(--color-base-fair-500);
  --color-base-brave-700: var(--color-base-fair-900);
  --color-base-energized-500: var(--color-base-fair-900);
}

.subsets:hover {
  --icon-color: var(--color-base-fair-500);
}

.rules {
  --color-base-brave-100: var(--color-base-fluent-100);
  --color-base-brave-500: var(--color-base-fluent-500);
  --color-base-brave-700: var(--color-base-fluent-900);
  --color-base-energized-500: var(--color-base-fluent-900);
}

.rules:hover {
  --icon-color: var(--color-base-fluent-500);
}

.sidebar {
  --column-width: 230px;
  --column-z-index: 1;
  --column-position: fixed;
  --column-height: 100%;
  border-right: 1px solid rgb(var(--color-grey-stable-500));
}

.sidebar+rmv-column {
  margin-left: 230px;
}

.sidebar.collapsed+rmv-column {
  margin-left: 62px;
}

.sidebar.collapsed rmv-button rmv-content {
  --host-display: none;
}

.sidebar.collapsed rmv-tooltip rmv-button {
  min-width: 61px;
}

.sidebar-inner {
  --column-position: sticky;
}

.sidebar.collapsed {
  --column-width: 62px;
}

.sidebar.collapsed rmv-row[grow="false"] {
  --row-opacity: 0;
}

.sidebar.collapsed rmv-row[grow="false"]:first-of-type {
  --row-height: 0;
}

.sidebar.collapsed rmv-row[grow="false"]:not(:first-of-type) {
  --row-padding: 0;
}

.sidebar.collapsed rmv-content[size="meta"] {
  --content-line-height: 1;
}

.sidebar-toggle {
  --button-background-color: rgb(var(--color-base-light));
  --button-padding: 7px 8px 7px 6px;
  --button-border-width: 1px;
  --button-border-style: solid;
  --button-border-color: rgb(var(--color-grey-stable-500));
  --button-box-shadow: var(--elevation-sm);
  --button-border-top-left-radius: var(--radius-lg);
  --button-border-top-right-radius: var(--radius-lg);
  --button-border-bottom-left-radius: var(--radius-lg);
  --button-border-bottom-right-radius: var(--radius-lg);
  --button-z-index: 3;
  position: absolute;
  right: -12px;
  top: 24px;
}

.sidebar.collapsed .sidebar-toggle {
  --icon-transform: rotate(180deg);
  --button-padding: 7px 6px 7px 8px;
}

/* Subsets: Needed for the specific 'Folders' accordion styling on the Subsets overview page */
rmv-accordion:not([open]).folders-accordion {
  --accordion-summary-padding: 24px 20px;
  --accordion-summary-margin: -24px -20px 0;
  --accordion-summary-background-color: rgb(var(--color-stable-100));
}

/* Subsets: Needed for the specific 'Folders' accordion to hide/show the grid/list view trigger */
rmv-accordion:not([open]).folders-accordion+turbo-frame .view-dropdown {
  display: none;
}

.view-dropdown {
  position: absolute;
  top: 0;
  right: 0;
  margin: 16px 28px;
  z-index: 2;
}

/* Subsets: Needed for the specific 'Folders' card styling on the Subsets overview page */
.folder-card {
  --card-max-width: 213px;
  --card-border-color: transparent;
}

.folder-card:hover {
  --card-background-color: rgb(var(--color-energized-100));
}

/* Table row: show handle and action trigger only on hover */
.table-row-hover-actions sds-row .handle,
.table-row-hover-actions sds-row sds-action-trigger {
  opacity: 0;
}

.table-row-hover-actions sds-row:hover .handle,
.table-row-hover-actions sds-row:hover sds-action-trigger,
.table-row-hover-actions sds-row sds-action-trigger[open] {
  opacity: 1;
}

/* While dragging: disable hover logic, only show handle on the dragged row */
.table-row-hover-actions sds-row.sortable-chosen .handle {
  opacity: 1;
}

.table-row-hover-actions:has(.sortable-chosen) sds-row:not(.sortable-chosen):hover .handle,
.table-row-hover-actions:has(.sortable-chosen) sds-row:not(.sortable-chosen):hover sds-action-trigger {
  opacity: 0;
}

/* Sortable styling needed for dragging */
.grabbing * {
  cursor: grabbing;
  --button-cursor: grabbing;
}

.grabbing *:not(rmv-row.sortable-chosen) {
  --row-background-color: transparent;
}

.grabbing .handle,
.handle:active {
  cursor: grabbing;
  --button-cursor: grab;
}

.handle,
.handle:focus,
.handle:active {
  cursor: grabbing;
  --button-cursor: grabbing;
}

.handle:hover {
  cursor: grab;
  --button-cursor: grab;
}

rmv-row.sortable-chosen.sortable-ghost,
sds-row.sortable-chosen.sortable-ghost {
  opacity: 0;
}

/* Preview: Styling for the toolbar buttons */
rmv-button.preview-menu-item[variant="tertiary"] {
  --button-background-color: rgb(var(--color-light));
  --button-border: transparent;
  --button-box-shadow: none;
  --button-disabled-background-color: transparent;
  --button-border-top-left-radius: var(--radius-sm);
  --button-border-top-right-radius: var(--radius-sm);
  --button-border-bottom-left-radius: var(--radius-sm);
  --button-border-bottom-right-radius: var(--radius-sm);
}

rmv-button.preview-menu-item[variant="tertiary"] rmv-icon {
  --icon-color: rgb(var(--color-brave-500));
}

rmv-button.preview-menu-item[variant="tertiary"]:hover {
  --button-background-color: rgb(var(--color-brave-100));
  --button-border: transparent;
  --button-box-shadow: none;
}

rmv-button.preview-menu-item[variant="tertiary"]:active {
  --button-background-color: rgb(var(--color-brave-100));
  --button-border: transparent;
  --button-box-shadow: none;
}

rmv-button.preview-menu-item[variant="tertiary"][selected] {
  --button-background-color: rgb(var(--color-brave-100));
  --button-background-image: none;
  --button-border: transparent;
  --button-box-shadow: none;
}

rmv-button.preview-menu-item[variant="tertiary"][selected]::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 2px;
  background-color: rgb(var(--color-energized-500));
}

rmv-button.preview-menu-item[variant="tertiary"][selected]:hover::after {
  background-color: rgb(var(--color-energized-500));
}

rmv-button.preview-menu-item[variant="tertiary"][selected]:active::after {
  content: none;
}

rmv-button.preview-menu-item[disabled] {
  --button-disabled-background-color: transparent;
  --button-outline-border-color: none;
  --button-box-shadow: none;
}

rmv-button.preview-menu-item[disabled] rmv-icon {
  --icon-color: rgb(var(--color-stable-800));
}

rmv-button.preview-menu-item[disabled]:hover,
rmv-button.preview-menu-item[disabled]:active {
  --button-background-color: var(--button-disabled-background-color);
}

rmv-button.preview-menu-item[icon] {
  --button-padding: 8px;
}

.badge-notch {
  position: absolute;
  top: 0;
  right: 20px;
  --badge-border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  --badge-border-width: 0 1px 1px;
}

.badge-notch-sidebar {
  position: absolute;
  top: 0;
  right: 28px;
  --badge-border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  --badge-border-width: 0 1px 1px;
}

.explorer-search-preview {
  --input-host-width: 330px;
}

.explorer-search {
  --input-height: 40px;
  --input-width: 400px;
  --input-color: rgba(var(--color-light));
  --input-background-color: rgba(var(--color-light), 0.2);
  --input-placeholder-color: rgb(var(--color-light));
  --input-border-width: 0;
  --input-padding: 10px 16px;
}

.explorer-search rmv-icon {
  --icon-color: rgb(var(--color-light));
}

.explorer-search rmv-button[variant="tertiary"]:hover rmv-icon {
  --icon-color: rgb(var(--color-energized-700));
}

.explorer-search:hover {
  --input-background-color: rgba(var(--color-light), 0.28);
}

.explorer-search:active,
.explorer-search:focus-within,
.explorer-search[value]:not([value=""]) {
  --input-color: rgba(var(--color-dark));
  --input-background-color: rgba(var(--color-light), 1);
}

.explorer-search:active rmv-icon,
.explorer-search:focus-within rmv-icon,
.explorer-search[value]:not([value=""]) rmv-icon {
  --color-base-royal-500: var(--color-stable-900);
  --icon-color: rgb(var(--color-stable-900));
}

.explorer-card {
  --card-position: absolute;
  --card-overflow: hidden;
  --card-width: 680px;
  --card-min-width: 250px;
  --card-margin: 13px 0 0 0;
  --card-z-index: 1;
}

.explorer-button {
  --button-height: 44px;
  --button-background-color: rgb(var(--color-light));
  --button-border: none;
  --button-box-shadow: none;
  --button-border-radius: 0;
  --explorer-icon-background-color: rgba(var(--color-balanced-500), 0.1);
}

.explorer-button:hover {
  --button-background-color: rgb(var(--color-balanced-100));
}

.explorer-button:hover rmv-content {
  --color-base-brave-500: rgba(var(--color-energized-700), 1);
}

.explorer-button:hover .hidden-arrow {
  display: flex;
}

.explorer-button .explorer-icon {
  /* Custom styling for the backdrop of the icon (no need to add
			the possibility to overrule */
  margin-left: 20px;
  z-index: 1;
}

.explorer-button .explorer-icon:before {
  content: "";
  width: 36px;
  height: 36px;
  border-radius: 4px;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  position: absolute;
  background-color: var(--explorer-icon-background-color);
  z-index: -1;
}

.explorer-button .explorer-icon[color="stable-900"]:before {
  --explorer-icon-background-color: rgba(var(--color-stable-100), 1);
}

.explorer-button .explorer-icon[color="royal-500"]:before {
  --explorer-icon-background-color: rgba(var(--color-royal-100), 1);
}

.explorer-button .explorer-icon[color="fluent-500"]:before {
  --explorer-icon-background-color: rgba(var(--color-fluent-100), 1);
}

.explorer-button .explorer-icon[color="fair-500"]:before {
  --explorer-icon-background-color: rgba(var(--color-fair-100), 1);
}

.explorer-button .explorer-icon[color="brave-500"]:before {
  --explorer-icon-background-color: rgba(var(--color-brave-100), 1);
}

.explorer-button-nested {
  --button-height: 36px;
}

.badge-notch {
  position: absolute;
  right: 20px;
  --badge-border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  --badge-border-width: 0 1px 1px;
}

.explorer-response,
.explorer-response>div {
  width: 100%;
}

.explorer-response rmv-code-editor,
.explorer-response>div rmv-code-editor {
  --input-border-width: 0;
  --input-border-top-left-radius: 0;
  --input-border-top-right-radius: 0;
  --input-border-bottom-left-radius: 0;
  --input-border-bottom-right-radius: 0;
}

.explorer-response rmv-code-editor:hover,
.explorer-response rmv-code-editor:focus-within,
.explorer-response>div rmv-code-editor:hover,
.explorer-response>div rmv-code-editor:focus-within {
  --input-border-width: 1px;
  --input-border-color: transparent;
}

.explorer-response rmv-code-editor .ace-github .ace_gutter,
.explorer-response>div rmv-code-editor .ace-github .ace_gutter {
  border-top-left-radius: 0;
}

.pointer-events-none {
  pointer-events: none;
}

.modal-full-height {
  height: calc(100vh - 40px);
}

rmv-code-editor.code-editor-borderless {
  --input-border-width: 0;
  --input-border-top-left-radius: 0;
  --input-border-top-right-radius: 0;
  --input-border-bottom-left-radius: 0;
  --input-border-bottom-right-radius: 0;
  --input-padding: 1px 1px 0;
}

rmv-code-editor.code-editor-borderless:hover,
rmv-code-editor.code-editor-borderless:focus-within {
  --input-border-width: 0;
  --input-border-color: transparent;
}

.divider-with-color {
  --divider-border-color: rgba(var(--color-light));
}

.active-avatar {
  --avatar-background-color: rgb(var(--color-stable-500));
  --content-color: rgb(var(--color-dark));
  --avatar-border-width: 0;
}

.popover-corner {
  position: absolute;
  top: 0;
  right: 0;
  padding: 14px 20px;
}

/* Subset rule (variable assignments & activations): Styling needed for collapsible which have popovers, this can be reused in other features. Apply on the wrapper around the accordion (rmv-card i.e.) */
.collapsible-with-popover rmv-accordion[open]+rmv-column,
.collapsible-with-sortable .handle:has(+ rmv-accordion[open]) {
  border-bottom: 1px solid rgb(var(--color-grey-stable-500));
}

.collapsible-with-popover rmv-accordion[open]>rmv-column {
  --column-width: calc(100% + 60px);
}

.collapsible-with-sortable rmv-accordion>rmv-column {
  margin-left: -40px;
  --column-width: calc(100% + 40px);
}

.collapsible-with-sortable.collapsible-with-popover rmv-accordion>rmv-column {
  --column-width: calc(100% + 100px);
}

.line-clamp-1 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.table-default>rmv-row,
.table-default>*>rmv-row {
  min-height: 32px;
}

.table-meta>rmv-row,
.table-meta>*>rmv-row {
  min-height: 36px;
}

.table-no-hover-effect rmv-row[is="table-row"]:hover {
  --row-background-color: currentcolor;
}

rmv-snackbar.alerts-and-notices {
  --card-margin: 50px 0 0 0;
  --card-width: max-content;
}

.no-shrink {
  --row-flex-shrink: 0;
  /* Disable shrinking for row */
}

.modal-snackbar {
  position: fixed;
  top: 75px;
  width: 100%;
  right: 0;
  z-index: 2;
}

.table-scrollable rmv-table>rmv-row:first-child {
  --row-position: sticky;
  --row-z-index: 4;
  top: 0;
  --row-background-color: rgb(var(--color-grey-stable-100));
}

.table-scrollable rmv-table rmv-row>rmv-column>rmv-row>rmv-column:first-child {
  left: 0;
  --column-position: sticky;
  --column-z-index: 3;
  transition: all 1s;
}

.table-scrollable rmv-table>rmv-row:first-child>rmv-column:first-child {
  left: 0;
  --column-position: sticky;
  --column-z-index: 1;
  transition: all 1s;
}

.table-scrollable-scrolled rmv-table rmv-row>rmv-column:first-child {
  box-shadow: 5px 0px 7px -5px rgba(0, 0, 0, 0.08);
}

rmv-accordion.accordion-ellipsis {
  --accordion-width: 100%;
}

rmv-accordion[open].debugger-accordion {
  flex-grow: 1;
  align-items: flex-start;
  --accordion-background-color: rgb(var(--color-light));
}

#memory_scrollable
  rmv-column[padding="0/0/0/20"]
  > rmv-divider[variant="dotted"] {
  margin-left: 14px;
}

#memory_scrollable > rmv-accordion[open] + rmv-divider[variant="dotted"] {
  margin-left: 14px;
}

#memory_scrollable
  rmv-column[padding="4/0/8/40"]
  > rmv-divider[variant="dotted"] {
  position: relative;
  left: -12px;
  width: calc(100% + 32px);
}

#memory_scrollable
  rmv-column[padding="0/0/0/40"]
  > rmv-divider[variant="dotted"] {
  position: relative;
  left: -12px;
  width: calc(100% + 32px);
}

rmv-timeline rmv-icon.timeline-item-icon {
  --timeline-item-icon-outline: 4px solid rgb(var(--color-grey-stable-100));
}

.resizable-handle {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  cursor: ns-resize;
  z-index: 10;
}

rmv-accordion.accordion-ellipsis {
  --accordion-width: 100%;
}

/* Hide invisible button in table row */
.table-hover-button {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 4px;
  --button-border-bottom-left-radius: 50%;
  --button-border-bottom-right-radius: 50%;
  --button-border-top-left-radius: 50%;
  --button-border-top-right-radius: 50%;
  --button-height: 20px;
  --button-width: 20px;
}

.hide-button-opacity {
  opacity: 0;
}

.show-button-opacity {
  opacity: 1;
}

.search-in-answers-table[disabled] {
  --input-border-width: 0px;
  --input-padding: 0px 16px;
}

.select-wide-dropdown {
  --select-choices-list-dropdown-width: 360px;
}

.diagram-modal-scrollbar {
  --scrollable-max-height: calc(100vh - 283px);
  overflow: auto;
  --scrollable-scrollbar-width-enum: thin;
  --scrollable-scrollbar-gutter: stable;
  --scrollable-scrollbar-color: rgb(var(--color-grey-stable-500));
}

.diagram-modal-search {
  --input-background-color: rgba(var(--color-light), 1);
}

.diagram-modal-activation-button rmv-content {
  --content-font-size: var(--font-size-meta);
  --content-font-weight: 500;
}

rmv-row#preview-toolbar {
  position: sticky;
  top: 60px;
  z-index: 99;
}

.subset-rules-fields {
  --column-width: calc(100% - 20px);
  max-width: 759px;
}

.subset-rules-variables {
  --column-width: calc(100% - 40px);
  max-width: 759px;
}

/* This selector targets rmv-spinner elements within .search-with-spinner elements that either have no value or an empty value. */
.search-with-spinner:is(:not([value]), [value=""]) rmv-spinner[slot="suffix"] {
  --host-display: inline-flex;
}

/* This selector hides the last rmv-divider in the ruleset outcomes edit table */
#bulk_ruleset_outcomes_form rmv-table rmv-row:last-of-type rmv-divider {
  display: none;
}

#bulk_ruleset_outcomes_form rmv-row.sortable-drag rmv-divider {
  display: none;
}

.test-cases-notice-button rmv-content {
  --content-font-size: var(--font-size-meta);
}

.filter-select[open] {
  --select-host-position: fixed;
}

.sidebar+rmv-divider+rmv-column .table-popover {
  bottom: 20px;
  position: fixed;
  --card-inset: auto auto calc(100% + 8px) calc(50% + 100px);
}

.sidebar.collapsed+rmv-divider+rmv-column .table-popover {
  --card-inset: auto auto calc(100% + 8px) calc(50% + 30px);
}

rmv-action-trigger.filter-component-action-trigger[size="small"] {
  --button-width: auto;
  --button-padding: 8px 12px 8px 12px;
  --button-height: 44px;
  --host-max-width: 100%;
  --row-flex-shrink: 1;
}

rmv-action-trigger.filter-component-action-trigger[size="medium"] {
  --button-padding: 12px 16px;
  --row-flex-shrink: 1;
  --host-max-width: 100%;
}

/* SDS Utility classes */
sds-modal sds-column form {
  display: contents;
}

.sds-flex {
  flex: 1;
}

.sds-fit-content {
  --row-width: fit-content;
}

.sds-no-shrink {
  flex-shrink: 0;
}

.sds-popover-namespace {
  --card-width: 270px;
}

/* Table styling for full-width tables with dividers */
sds-table.table-full-width sds-row {
  padding: 0 var(--spacing-700);
}

/* Header view component: breadcrumbs title max width */
.header-breadcrumbs-title {
  max-width: 980px;
}

/* Navigation */
sds-navigation-bar[direction="horizontal"] {
  z-index: 2;
  position: sticky;
  top: 0;
}

sds-navigation-bar[direction="horizontal"]::part(logo),
sds-navigation-bar[direction="horizontal"]::part(user) {
  padding: var(--spacing-none) var(--spacing-600);
}

sds-navigation-bar[direction="horizontal"]::part(trigger) {
  padding: var(--spacing-none) var(--spacing-200);
}

sds-navigation-bar[direction="horizontal"]::part(content) {
  padding: var(--spacing-none);
}

sds-navigation-bar[direction="horizontal"] sds-button.navigation-button,
sds-navigation-bar[direction="horizontal"] sds-action-trigger.navigation-button {
  --button-height: 40px;
  --button-padding: var(--spacing-none) var(--spacing-400);
  --button-border-top-left-radius: var(--radius-default);
  --button-border-top-right-radius: var(--radius-default);
  --button-border-bottom-left-radius: var(--radius-default);
  --button-border-bottom-right-radius: var(--radius-default);
}

sds-navigation-bar[direction="horizontal"] sds-button.navigation-button,
sds-navigation-bar[direction="horizontal"] sds-action-trigger.navigation-button {
  --button-color: var(--text-action-inverse);
}

sds-navigation-bar[direction="horizontal"] sds-button.navigation-button sds-icon,
sds-navigation-bar[direction="horizontal"] sds-action-trigger.navigation-button sds-icon,
sds-navigation-bar[direction="horizontal"] sds-action-trigger.navigation-button sds-icon[slot="chevron"] {
  --icon-fill: var(--icon-action-inverse);
}

sds-navigation-bar[direction="horizontal"] sds-button.navigation-button:hover,
sds-navigation-bar[direction="horizontal"] sds-action-trigger.navigation-button:hover {
  --button-background-color: var(--background-transparent-inverse-secondary);
}

sds-navigation-bar[direction="horizontal"] sds-button.navigation-button:active {
  --button-background-color: var(--background-transparent-default);
}

sds-navigation-bar[direction="horizontal"] sds-action-trigger[open].navigation-button {
  --content-color: var(--text-action-active);
  --button-color: var(--text-action-active);
  --button-background-color: var(--background-default);
}

sds-navigation-bar[direction="horizontal"] sds-action-trigger[open].navigation-button sds-icon {
  --icon-fill: var(--icon-action-default);
}

sds-navigation-bar[direction="horizontal"] sds-action-trigger[open].navigation-button sds-icon[slot="chevron"] {
  --icon-fill: var(--icon-action-active);
}

sds-navigation-bar[direction="horizontal"] sds-search {
  --input-height: 40px;
  --input-placeholder-color: var(--text-inverse);
  --input-background-color: var(--background-transparent-inverse-secondary);
  --input-outline-color: transparent;
  --search-input-prefix-color: var(--text-inverse);
}

sds-navigation-bar[direction="horizontal"] sds-search:hover {
  --input-background-color: var(--background-transparent-inverse-default);
}

sds-navigation-bar[direction="horizontal"] sds-search:active,
sds-navigation-bar[direction="horizontal"] sds-search:focus,
sds-navigation-bar[direction="horizontal"] sds-search:focus-within,
sds-navigation-bar[direction="horizontal"] sds-search[value]:not([value=""]) {
  --search-input-prefix-color: var(--icon-input-active);
  --input-color: var(--text-input-default);
  --input-background-color: var(--background-input-default);
}

/* Sidebar Navigation */
sds-navigation-bar[direction="vertical"] {
  z-index: 1;
  position: sticky;
  top: 60px;
  height: calc(100vh - 60px);
}

sds-navigation-bar[direction="vertical"] {
  --navigation-bar-min-width: 230px;
}

/* Sidebar Navigation: Content templat/slot needs custom padding and gap to match design */
sds-navigation-bar[direction="vertical"]::part(content) {
  padding: var(--spacing-700) var(--spacing-300);
  gap: var(--spacing-300);
}

sds-navigation-bar[direction="vertical"][collapsed] {
  --navigation-bar-min-width: 67px;
}

sds-navigation-bar[direction="vertical"][collapsed] sds-button sds-badge {
  display: none;
}

sds-navigation-bar[direction="vertical"] > sds-column:not([slot]) {
  padding: var(--spacing-none);
}

sds-navigation-bar[direction="vertical"] > sds-column:not([slot]) > sds-column {
  gap: var(--spacing-none);
}

/* Sidebar Navigation: Collapse button styling (TO-DO: Put this as default styling in sds-navigation-bar) */
sds-navigation-bar[direction="vertical"] sds-button[slot="collapse"] {
  top: 16px;
  right: -12px;
}

sds-navigation-bar[direction="vertical"] sds-button[slot="collapse"] sds-card {
  --card-border-radius: var(--radius-round);
  --card-box-shadow: 0;
  --card-justify-content: center;
  --card-align-items: center;
  width: 24px;
  height: 24px;
}

sds-navigation-bar[direction="vertical"] sds-button:not([slot="collapse"]) {
  position: relative;
  --button-height: 48px;
}

sds-navigation-bar[direction="vertical"] sds-button[selected]:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: -12px;
  right: 0;
  width: calc(230px - 1px);
  height: 100%;
  pointer-events: none;
}

sds-navigation-bar[direction="vertical"][collapsed] sds-button[selected]:before {
  left: -13px;
  width: calc(67px - 1px);
}

sds-navigation-bar[direction="vertical"] sds-button[selected]:after {
  content: "";
  position: absolute;
  inset: 12px auto 12px 0;
  left: -12px;
  width: 2px;
}

sds-navigation-bar[direction="vertical"][collapsed] sds-button[selected]:after {
  left: -13px;
}

/* Sidebar Navigation: Default button styling */
sds-navigation-bar[direction="vertical"] sds-button[selected]:before {
  background-color: var(--background-highlight);
}

sds-navigation-bar[direction="vertical"] sds-button[selected]:after {
  background-color: var(--icon-action-selected);
}


/* Sidebar Navigation: Rulesets button styling */
sds-navigation-bar[direction="vertical"] sds-button.rulesets-button[selected],
sds-navigation-bar[direction="vertical"] sds-button.rulesets-button:hover {
  --button-color: var(--text-accent-3);
  --icon-fill: var(--icon-accent-3);
}

sds-navigation-bar[direction="vertical"] sds-button.rulesets-button[selected]:before {
  background-color: var(--background-accent-3-tertiary);
}

sds-navigation-bar[direction="vertical"] sds-button.rulesets-button[selected]:after {
  background-color: var(--icon-accent-3);
}

/* Sidebar Navigation: Subsets button styling */
sds-navigation-bar[direction="vertical"] sds-button.subsets-button[selected],
sds-navigation-bar[direction="vertical"] sds-button.subsets-button:hover {
  --button-color: var(--text-accent-1);
  --icon-fill: var(--icon-accent-1);
}

sds-navigation-bar[direction="vertical"] sds-button.subsets-button[selected]:before {
  background-color: var(--background-accent-1-tertiary);
}

sds-navigation-bar[direction="vertical"] sds-button.subsets-button[selected]:after {
  background-color: var(--icon-accent-1);
}

/* Sidebar Navigation: Rules button styling */
sds-navigation-bar[direction="vertical"] sds-button.rules-button[selected],
sds-navigation-bar[direction="vertical"] sds-button.rules-button:hover {
  --button-color: var(--text-accent-2);
  --icon-fill: var(--icon-accent-2);
}

sds-navigation-bar[direction="vertical"] sds-button.rules-button[selected]:before {
  background-color: var(--background-accent-2-tertiary);
}

sds-navigation-bar[direction="vertical"] sds-button.rules-button[selected]:after {
  background-color: var(--icon-accent-2);
}