/**
 * Rate Management — aligned with sh-styles / Bootstrap (brand tokens, readable contrast).
 */
.rate-mgmt-page .rm-reveal {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.rate-mgmt-page .rm-reveal.visible {
  opacity: 1;
  transform: none;
}
.rate-mgmt-page .rm-reveal-delay-1 { transition-delay: 0.08s; }
.rate-mgmt-page .rm-reveal-delay-2 { transition-delay: 0.16s; }
.rate-mgmt-page .rm-reveal-delay-3 { transition-delay: 0.24s; }
.rate-mgmt-page .rm-reveal-delay-4 { transition-delay: 0.32s; }

/* Hero — light surface, site typography */
.rate-mgmt-page .rm-hero-min {
  min-height: 0;
}
.rate-mgmt-page .rm-hero-divider {
  border-top-color: var(--neutral-200, hsl(214, 32%, 91%)) !important;
}
.rate-mgmt-page .rm-hier-card {
  background: var(--neutral-50, #f8fafc);
  border: 1px solid var(--neutral-200, hsl(214, 32%, 91%));
  border-radius: 1rem;
  padding: 1.5rem;
}
.rate-mgmt-page .rm-hier-step {
  border-left: 3px solid var(--brand-primary, #006397);
  background: #fff;
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  margin-bottom: 0.5rem;
}
.rate-mgmt-page .rm-hier-arrow {
  color: var(--neutral-400, hsl(215, 20%, 65%));
  font-size: 0.85rem;
  padding-left: 1.25rem;
  margin: 0.15rem 0;
}
.rate-mgmt-page .rm-chip {
  font-size: 0.75rem;
  font-weight: 500;
  padding: 0.35rem 0.65rem;
  border-radius: 50rem;
  background: var(--brand-50, #f0f9ff);
  color: var(--brand-700, #006ba8);
  border: 1px solid var(--brand-200, #b8e7ff);
}
.rate-mgmt-page .rm-stat-label {
  font-size: 0.75rem;
  color: var(--neutral-600, hsl(215, 19%, 35%));
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.rate-mgmt-page .rm-stat-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--brand-primary, #006397);
}

/* Capabilities — compact horizontal cards, tight grid */
.rate-mgmt-page .rm-capabilities-section .feature-title {
  font-size: clamp(1.35rem, 2.2vw, 1.65rem);
  line-height: 1.25;
}

.rate-mgmt-page .rm-capabilities-row {
  --bs-gutter-x: 0.5rem;
  --bs-gutter-y: 0.5rem;
}
@media (min-width: 768px) {
  .rate-mgmt-page .rm-capabilities-row {
    --bs-gutter-x: 0.625rem;
    --bs-gutter-y: 0.625rem;
  }
}
.rate-mgmt-page .rm-cap-card {
  position: relative;
  border: 1px solid var(--neutral-200, hsl(214, 32%, 91%));
  border-radius: 0.65rem;
  height: 100%;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.rate-mgmt-page .rm-cap-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65rem;
  bottom: 0.65rem;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, var(--brand-600, #0088d2) 0%, var(--brand-primary, #006397) 100%);
  opacity: 0.9;
}
.rate-mgmt-page .rm-cap-card-inner {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.65rem 0.75rem 0.65rem 0.85rem;
  min-height: 100%;
}
.rate-mgmt-page .rm-cap-card:hover {
  border-color: var(--brand-200, #b8e7ff);
  box-shadow: 0 0.35rem 1rem rgba(0, 99, 151, 0.08);
}
.rate-mgmt-page .rm-cap-icon {
  flex-shrink: 0;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, var(--brand-50, #f0f9ff), rgba(0, 136, 210, 0.08));
  color: var(--brand-600, #0088d2);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.9) inset;
}
.rate-mgmt-page .rm-cap-icon .material-symbols-rounded {
  font-size: 1.35rem;
}
.rate-mgmt-page .rm-cap-copy {
  min-width: 0;
  padding-top: 0.1rem;
}
.rate-mgmt-page .rm-cap-title {
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--neutral-900, hsl(222, 47%, 11%));
  margin: 0 0 0.2rem;
}
.rate-mgmt-page .rm-cap-desc {
  font-size: 0.78rem;
  line-height: 1.42;
  color: var(--neutral-600, hsl(215, 19%, 35%));
  margin: 0;
}

@media (prefers-reduced-motion: reduce) {
  .rate-mgmt-page .rm-cap-card {
    transition: none;
  }
}

/* Streamlined strip — softer mint, dark text (AA on body) */
.rate-mgmt-page .rm-streamlined-rate {
  background: linear-gradient(
    135deg,
    var(--success-100, #d2f9e5) 0%,
    var(--brand-50, #f0f9ff) 100%
  ) !important;
  border: 1px solid var(--neutral-200, hsl(214, 32%, 91%));
}
.rate-mgmt-page .rm-streamlined-rate .feature-title {
  color: var(--neutral-900, hsl(222, 47%, 11%));
}
.rate-mgmt-page .rm-streamlined-rate .feature-subtitle {
  color: var(--neutral-700, hsl(215, 25%, 27%)) !important;
}

/*
 * Streamlined workflow: boxed aspect-ratio; MP4 aligns via JS (applyRmFlowAspectRatio).
 * No overlay mask / buffer gating — extra compositor layers correlated with flashes + faux “scan lines” in Chrome.
 * Slight +6px overscan centered with translate hides object-fit letterbox seams (vertical + horizontal) on fractional layouts.
 */
.rate-mgmt-page .rm-flow-wrap {
  position: relative;
  width: 95%;
  max-width: 900px;
  line-height: 0;
  border-radius: 0.375rem;
  overflow: hidden;
  background: #fafcfd;
  color-scheme: light;
}

.rate-mgmt-page .rm-flow-video {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 1;
  box-sizing: border-box;
  width: calc(100% + 6px) !important;
  height: calc(100% + 6px) !important;
  max-width: none;
  max-height: none;
  margin: 0;
  padding: 0;
  transform: translate(-50%, -50%);
  transition: none;
  object-fit: contain;
  object-position: center center;
  display: block;
  opacity: 1;
  pointer-events: none;
  appearance: none;
  border: none;
  box-shadow: none;
  background: transparent;
  outline: none !important;
  -webkit-tap-highlight-color: transparent;
}

.rate-mgmt-page .rm-flow-video:focus,
.rate-mgmt-page .rm-flow-video:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

.rate-mgmt-page .rm-flow-video:-moz-focusring {
  outline: none !important;
}

/* Decorative clip: Chromium/Safari can briefly flash native media chrome over the viewport */
.rate-mgmt-page .rm-flow-video::-webkit-media-controls,
.rate-mgmt-page .rm-flow-video::-webkit-media-controls-enclosure,
.rate-mgmt-page .rm-flow-video::-webkit-media-controls-overlay-enclosure {
  display: none !important;
}

