.roi-focus-modal {
  overflow: hidden;
}

.roi-focus-modal .modal-body {
  height: calc(100vh - 72px);
  overflow: hidden;
}

.roi-focus-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(330px, 410px);
  height: 100%;
  min-height: 0;
}

.roi-focus-stage {
  padding: 1rem;
  background: linear-gradient(180deg, #232933 0%, #181d25 100%);
  border-right: 1px solid #323844;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0.85rem;
  min-height: 0;
  overflow: hidden;
}

.roi-focus-stage h6 {
  color: #f2f7ff;
}

.roi-focus-stage .text-secondary {
  color: #aebdce !important;
}

.roi-focus-stage__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.roi-focus-stage__intro {
  min-width: 0;
}

.roi-focus-stage__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.roi-focus-stage__mode {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background: rgba(123, 160, 210, 0.15);
  color: #d8e7fa;
  font-size: 0.82rem;
  font-weight: 700;
}

.roi-focus-stage__eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #8aa6c8;
  margin-bottom: 0.35rem;
}

.roi-focus-editor-card {
  background: linear-gradient(180deg, #2d333d 0%, #242a33 100%);
  border: 1px solid #39414d;
  border-radius: 1rem;
  padding: 0;
  box-shadow: 0 18px 36px rgba(4, 10, 18, 0.32);
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.roi-focus-editor-toolbar {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.7rem;
  background: #323842;
  border-bottom: 1px solid #474e5b;
}

.roi-focus-editor-toolbar .media-tool-btn:disabled {
  background: #2c3139;
  border-color: #424956;
  color: #6f7b8c;
  opacity: 1;
}

.roi-focus-editor-frame {
  position: relative;
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
  min-height: 260px;
  border-radius: 0;
  overflow: hidden;
  background:
    linear-gradient(45deg, rgba(255, 255, 255, 0.04) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255, 255, 255, 0.04) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(255, 255, 255, 0.04) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(255, 255, 255, 0.04) 75%),
    linear-gradient(180deg, #20252d 0%, #171b22 100%);
  background-size: 18px 18px, 18px 18px, 18px 18px, 18px 18px, auto;
  background-position: 0 0, 0 9px, 9px -9px, -9px 0, center;
}

.roi-focus-preview-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: transparent;
}

.roi-focus-editor-overlay {
  position: absolute;
  inset: 0;
  pointer-events: auto;
}

.roi-focus-editor-overlay.is-dragging-roi {
  cursor: grabbing;
}

.roi-focus-editor-overlay.is-dragging-poi {
  cursor: all-scroll;
}

.roi-focus-editor-overlay.is-resizing-roi {
  cursor: default;
}

.roi-focus-canvas-box {
  position: absolute;
  border: 2px solid var(--roi-focus-accent, #ff5b5b);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--roi-focus-accent, #ff5b5b) 18%, transparent);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  cursor: grab;
}

.roi-focus-canvas-box.is-active {
  border-width: 3px;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--roi-focus-accent, #ff5b5b) 35%, white), inset 0 0 0 1px rgba(255, 255, 255, 0.28);
}

.roi-focus-editor-overlay.is-dragging-roi .roi-focus-canvas-box.is-active {
  cursor: grabbing;
}

.roi-focus-canvas-badge {
  position: absolute;
  top: 0.35rem;
  left: 0.35rem;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 999px;
  background: rgba(14, 31, 54, 0.82);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
}

.roi-focus-canvas-poi {
  position: absolute;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 999px;
  background: #fff;
  border: 3px solid #0f2746;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 3px var(--roi-focus-accent, #ff5b5b), 0 0 0 5px rgba(255, 255, 255, 0.26);
  cursor: all-scroll;
}

.roi-focus-canvas-poi.is-active {
  border-color: #0f2746;
}

.roi-focus-editor-overlay.is-dragging-poi .roi-focus-canvas-poi.is-active {
  cursor: all-scroll;
}

.roi-focus-canvas-handle {
  position: absolute;
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 999px;
  border: 2px solid #0f2746;
  background: #fff;
  padding: 0;
  transform: translate(-50%, -50%);
}

.roi-focus-editor-overlay.is-resizing-roi .roi-focus-canvas-handle {
  pointer-events: auto;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--nw:not(:disabled) {
  top: 0;
  left: 0;
  cursor: nwse-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--n:not(:disabled),
.roi-focus-canvas-handle.roi-focus-canvas-handle--s:not(:disabled),
.roi-focus-canvas-handle.roi-focus-canvas-handle--w:not(:disabled),
.roi-focus-canvas-handle.roi-focus-canvas-handle--e:not(:disabled) {
  width: 0.72rem;
  height: 0.72rem;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--n:not(:disabled) {
  top: 0;
  left: 50%;
  cursor: ns-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--ne:not(:disabled) {
  top: 0;
  left: 100%;
  cursor: nesw-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--w:not(:disabled) {
  top: 50%;
  left: 0;
  cursor: ew-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--e:not(:disabled) {
  top: 50%;
  left: 100%;
  cursor: ew-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--sw:not(:disabled) {
  top: 100%;
  left: 0;
  cursor: nesw-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--s:not(:disabled) {
  top: 100%;
  left: 50%;
  cursor: ns-resize;
}

.roi-focus-canvas-handle.roi-focus-canvas-handle--se:not(:disabled) {
  top: 100%;
  left: 100%;
  cursor: nwse-resize;
}

.roi-focus-preview-strip {
  background: linear-gradient(180deg, rgba(43, 50, 61, 0.96) 0%, rgba(34, 40, 49, 0.96) 100%);
  border: 1px solid #39414d;
  border-radius: 1rem;
  padding: 0.7rem 0.75rem 0.8rem;
  box-shadow: 0 12px 24px rgba(4, 10, 18, 0.22);
  overflow: hidden;
}

.roi-focus-preview-strip__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.roi-focus-preview-strip__title-row h6 {
  color: #f2f7ff;
  font-size: 0.98rem;
}

.roi-focus-preview-strip__mode {
  color: #9dbde4;
  font-size: 0.88rem;
  font-weight: 600;
}

.roi-focus-preview-strip__header--body {
  margin-bottom: 0.6rem;
}

.roi-focus-preview-strip__toggle {
  margin-left: auto;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid #556171;
  background: #39414d;
  color: #eef5ff;
}

.roi-focus-preview-strip__toggle:hover,
.roi-focus-preview-strip__toggle:focus {
  background: #465061;
  border-color: #6b7788;
  color: #fff;
}

.roi-focus-preview-strip__body {
  margin-top: 0.55rem;
}

.roi-focus-preview-strip.is-collapsed {
  padding-bottom: 0.7rem;
}

.roi-focus-preview-strip.is-collapsed .roi-focus-preview-strip__body {
  display: none;
}

.roi-focus-preview-ratio-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(150px, 172px);
  gap: 0.6rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.2rem;
  align-items: start;
}

.roi-focus-ratio-card {
  border: 1px solid #4b5565;
  border-radius: 0.85rem;
  background: #2a3039;
  padding: 0.5rem;
  min-width: 0;
}

.roi-focus-ratio-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
  font-size: 0.77rem;
  color: #eff5ff;
}

.roi-focus-ratio-card__status {
  color: #9fb2ca;
  font-weight: 700;
  white-space: nowrap;
}

.roi-focus-ratio-card__status.is-good {
  color: #198754;
}

.roi-focus-ratio-card__status.is-partial {
  color: #b7791f;
}

.roi-focus-ratio-card__status.is-bad {
  color: #b42318;
}

.roi-focus-ratio-card__frame {
  border-radius: 0.7rem;
  overflow: hidden;
  background: #1b2028;
  max-height: 110px;
}

.roi-focus-ratio-card__meta {
  margin-top: 0.45rem;
}

.roi-focus-ratio-card__mode {
  display: block;
  font-size: 0.74rem;
  line-height: 1.3;
  color: #51657f;
}

.roi-focus-ratio-card__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.roi-focus-sidebar {
  background: #fff;
  padding: 1rem;
  min-height: 0;
  overflow: auto;
}

.roi-focus-sidebar__item {
  border: 1px solid #d6e1ef;
  border-radius: 0.95rem;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(18, 42, 70, 0.08);
}

.roi-focus-sidebar__button,
.roi-focus-sidebar__button:not(.collapsed) {
  background: linear-gradient(110deg, #0f2746 0%, #1a5f88 100%);
  color: #f6fbff;
  box-shadow: none;
  border: 0;
  font-weight: 700;
}

.roi-focus-sidebar__button::after,
.roi-focus-sidebar__button:not(.collapsed)::after {
  filter: brightness(0) invert(1);
}

.roi-focus-sidebar .accordion-body {
  background: #fff;
}

.roi-focus-object-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.roi-focus-object-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
  --roi-focus-object-accent: #5c8fd1;
}

.roi-focus-object-main {
  border: 1px solid #d6e1ef;
  background: color-mix(in srgb, var(--roi-focus-object-accent) 10%, #f8fbff);
  border-radius: 0.85rem;
  width: 100%;
  text-align: left;
  padding: 0.65rem 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.roi-focus-object-row.is-active .roi-focus-object-main {
  border-color: var(--roi-focus-object-accent);
  background: color-mix(in srgb, var(--roi-focus-object-accent) 18%, #eef5ff);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--roi-focus-object-accent) 35%, transparent);
}

.roi-focus-object-index {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--roi-focus-object-accent) 72%, #183b66);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  flex: 0 0 auto;
}

.roi-focus-object-copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.roi-focus-object-copy strong,
.roi-focus-object-copy small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.roi-focus-object-copy small {
  color: #607693;
}

.roi-focus-object-actions {
  display: inline-flex;
  gap: 0.3rem;
}

@media (max-width: 991.98px) {
  .roi-focus-layout {
    grid-template-columns: 1fr;
  }

  .roi-focus-stage {
    border-right: 0;
    border-bottom: 1px solid #dce6f3;
  }

  .roi-focus-preview-strip__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .roi-focus-preview-strip__toggle {
    margin-left: 0;
  }
}
