.ior-rbd-shell,
.ior-rbd-shell *,
.ior-rbd-admin-wrap,
.ior-rbd-admin-wrap * {
    box-sizing: border-box;
}

.ior-rbd-shell {
    --rbd-navy: #062a44;
    --rbd-blue: #0c5f95;
    --rbd-sky: #eaf6ff;
    --rbd-line: #d7e4ef;
    --rbd-soft: #f5f9fd;
    --rbd-green: #0e8b5f;
    --rbd-amber: #c88700;
    --rbd-red: #b43131;
    --rbd-purple: #5b4bb7;
    --rbd-text: #173047;
    --rbd-muted: #63788b;
    color: var(--rbd-text);
    font-family: Verdana, Geneva, sans-serif;
    max-width: 1280px;
    margin: 0 auto;
    padding: 20px;
}

.ior-rbd-shell button,
.ior-rbd-shell input,
.ior-rbd-shell select,
.ior-rbd-shell textarea {
    font-family: Verdana, Geneva, sans-serif;
}

.ior-rbd-noscript {
    padding: 18px;
    border: 1px solid #efc2c2;
    border-radius: 14px;
    background: #fff6f6;
    color: #8a2424;
}

.ior-rbd-app {
    position: relative;
}

.ior-rbd-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #062a44 0%, #0b5d8f 56%, #1687b2 100%);
    color: #fff;
    border-radius: 28px;
    padding: 34px;
    box-shadow: 0 24px 60px rgba(4, 42, 68, .18);
}

.ior-rbd-hero:after {
    content: '';
    position: absolute;
    inset: auto -110px -160px auto;
    width: 430px;
    height: 430px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
}

.ior-rbd-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.45fr .9fr;
    gap: 22px;
    align-items: stretch;
}

.ior-rbd-kicker {
    margin: 0 0 10px;
    text-transform: uppercase;
    letter-spacing: .11em;
    font-size: 12px;
    font-weight: 700;
    color: #bfe7ff;
}

.ior-rbd-hero h1 {
    font-size: clamp(30px, 4vw, 50px);
    line-height: 1.04;
    margin: 0 0 14px;
    color: #fff;
}

.ior-rbd-hero p {
    margin: 0;
    font-size: 15px;
    line-height: 1.65;
    max-width: 760px;
    color: rgba(255, 255, 255, .9);
}

.ior-rbd-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.ior-rbd-local-card {
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: 24px;
    padding: 22px;
    backdrop-filter: blur(8px);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 240px;
}

.ior-rbd-local-card h2 {
    margin: 0 0 10px;
    color: #fff;
    font-size: 22px;
}

.ior-rbd-local-list {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.ior-rbd-local-list div {
    display: grid;
    grid-template-columns: 30px 1fr;
    gap: 10px;
    align-items: start;
    color: rgba(255, 255, 255, .92);
}

.ior-rbd-local-list strong {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .18);
    color: #fff;
    font-size: 13px;
}

.ior-rbd-btn {
    border: 0;
    cursor: pointer;
    border-radius: 14px;
    padding: 11px 15px;
    font-weight: 700;
    font-size: 13px;
    color: var(--rbd-navy);
    background: #fff;
    box-shadow: 0 8px 20px rgba(5, 42, 68, .13);
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
    text-decoration: none;
    display: inline-flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    line-height: 1.25;
}

.ior-rbd-btn:hover,
.ior-rbd-btn:focus {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(5, 42, 68, .18);
}

.ior-rbd-btn-primary {
    background: var(--rbd-blue);
    color: #fff;
}

.ior-rbd-btn-dark {
    background: var(--rbd-navy);
    color: #fff;
}

.ior-rbd-btn-soft {
    background: #e8f4fc;
    color: var(--rbd-navy);
    box-shadow: none;
}

.ior-rbd-btn-ghost {
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .26);
    color: #fff;
    box-shadow: none;
}

.ior-rbd-btn-danger {
    background: #fff1f1;
    color: #9d2525;
    box-shadow: none;
}

.ior-rbd-step-nav {
    margin: 22px 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.ior-rbd-step-card {
    border: 1px solid var(--rbd-line);
    background: #fff;
    border-radius: 22px;
    padding: 16px;
    min-height: 156px;
    text-align: left;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(6, 42, 68, .07);
}

.ior-rbd-step-card:before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 5px;
    background: #c9d9e7;
}

.ior-rbd-step-card.is-active {
    border-color: #7ac4ee;
    box-shadow: 0 18px 36px rgba(6, 42, 68, .13);
}

.ior-rbd-step-card.is-active:before {
    background: var(--rbd-blue);
}

.ior-rbd-step-card.is-complete:before {
    background: linear-gradient(90deg, #0e8b5f, #5cc18b);
}

.ior-rbd-step-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.ior-rbd-step-no {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: #e8f4fc;
    color: var(--rbd-blue);
    font-weight: 800;
    font-size: 13px;
}

.ior-rbd-step-card h3 {
    margin: 0 0 7px;
    color: var(--rbd-navy);
    font-size: 16px;
}

.ior-rbd-step-card p {
    margin: 0;
    color: var(--rbd-muted);
    font-size: 12px;
    line-height: 1.45;
}

.ior-rbd-step-metric {
    margin-top: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--rbd-navy);
    font-size: 12px;
    font-weight: 700;
}

.ior-rbd-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 700;
    background: #edf5fb;
    color: var(--rbd-blue);
    white-space: nowrap;
}

.ior-rbd-pill-green {
    background: #e3f5ed;
    color: #0b7350;
}

.ior-rbd-pill-amber {
    background: #fff3d8;
    color: #9c6700;
}

.ior-rbd-pill-red {
    background: #ffe9e9;
    color: #a22b2b;
}

.ior-rbd-workspace {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 28px;
    padding: 22px;
    box-shadow: 0 16px 44px rgba(6, 42, 68, .08);
}

.ior-rbd-workspace-header {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 18px;
}

.ior-rbd-workspace-header h2 {
    margin: 0 0 8px;
    color: var(--rbd-navy);
    font-size: 28px;
}

.ior-rbd-workspace-header p {
    margin: 0;
    color: var(--rbd-muted);
    line-height: 1.55;
    max-width: 840px;
}

.ior-rbd-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    justify-content: flex-end;
}

.ior-rbd-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.ior-rbd-card-grid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ior-rbd-info-card,
.ior-rbd-data-card,
.ior-rbd-panel {
    background: var(--rbd-soft);
    border: 1px solid var(--rbd-line);
    border-radius: 22px;
    padding: 18px;
}

.ior-rbd-info-card h3,
.ior-rbd-data-card h3,
.ior-rbd-panel h3 {
    margin: 0 0 10px;
    color: var(--rbd-navy);
    font-size: 17px;
}

.ior-rbd-info-card p,
.ior-rbd-data-card p,
.ior-rbd-panel p {
    margin: 0 0 12px;
    color: var(--rbd-muted);
    font-size: 13px;
    line-height: 1.55;
}

.ior-rbd-scale-list {
    display: grid;
    gap: 8px;
    margin: 12px 0;
}

.ior-rbd-scale-row {
    display: grid;
    grid-template-columns: 38px 1fr;
    gap: 10px;
    align-items: start;
    padding: 10px;
    border: 1px solid #dce9f4;
    border-radius: 14px;
    background: #fff;
}

.ior-rbd-scale-value {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    background: #edf5fb;
    display: grid;
    place-items: center;
    color: var(--rbd-blue);
    font-weight: 800;
}

.ior-rbd-scale-row strong {
    display: block;
    color: var(--rbd-navy);
    font-size: 13px;
}

.ior-rbd-scale-row span {
    color: var(--rbd-muted);
    font-size: 12px;
    line-height: 1.4;
}

.ior-rbd-matrix {
    display: grid;
    gap: 6px;
    width: 100%;
}

.ior-rbd-matrix-row {
    display: grid;
    gap: 6px;
}

.ior-rbd-matrix-cell {
    min-height: 48px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 8px;
    border: 1px solid rgba(6, 42, 68, .08);
    font-size: 11px;
    color: #153047;
    position: relative;
}

.ior-rbd-matrix-cell strong {
    font-size: 13px;
}

.ior-rbd-matrix-cell .dot {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: var(--rbd-navy);
    position: absolute;
    top: 5px;
    right: 5px;
    box-shadow: 0 0 0 3px rgba(255,255,255,.8);
}

.ior-rbd-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.ior-rbd-tab {
    border: 1px solid var(--rbd-line);
    background: #fff;
    color: var(--rbd-navy);
    border-radius: 999px;
    padding: 10px 13px;
    cursor: pointer;
    font-weight: 700;
    font-size: 12px;
}

.ior-rbd-tab.is-active {
    background: var(--rbd-navy);
    color: #fff;
    border-color: var(--rbd-navy);
}

.ior-rbd-register-layout {
    display: grid;
    grid-template-columns: .95fr 1.6fr;
    gap: 16px;
}

.ior-rbd-register-summary {
    display: grid;
    gap: 12px;
}

.ior-rbd-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.ior-rbd-stat {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 18px;
    padding: 14px;
}

.ior-rbd-stat span {
    display: block;
    color: var(--rbd-muted);
    font-size: 11px;
    margin-bottom: 5px;
}

.ior-rbd-stat strong {
    color: var(--rbd-navy);
    font-size: 26px;
}

.ior-rbd-card-list {
    display: grid;
    gap: 12px;
}

.ior-rbd-risk-card,
.ior-rbd-action-card {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-left: 7px solid #9db7cc;
    border-radius: 20px;
    padding: 15px;
    box-shadow: 0 10px 24px rgba(6, 42, 68, .055);
}

.ior-rbd-risk-card.is-selected,
.ior-rbd-action-card.is-selected {
    border-color: #8ac9ef;
    border-left-color: var(--rbd-blue);
    box-shadow: 0 16px 32px rgba(6, 42, 68, .12);
}

.ior-rbd-card-title-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 8px;
}

.ior-rbd-card-title-row h3,
.ior-rbd-card-title-row h4 {
    margin: 0;
    color: var(--rbd-navy);
    font-size: 16px;
    line-height: 1.35;
}

.ior-rbd-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin: 10px 0;
}

.ior-rbd-muted {
    color: var(--rbd-muted);
    font-size: 12px;
    line-height: 1.5;
}

.ior-rbd-empty {
    border: 1px dashed #b8cedf;
    background: #f7fbfe;
    color: var(--rbd-muted);
    border-radius: 20px;
    padding: 24px;
    text-align: center;
}

.ior-rbd-impact-layout {
    display: grid;
    grid-template-columns: .95fr 1.45fr;
    gap: 16px;
}

.ior-rbd-action-list-scroll {
    display: grid;
    gap: 10px;
    max-height: 680px;
    overflow: auto;
    padding-right: 4px;
}

.ior-rbd-impact-editor {
    background: linear-gradient(180deg, #f7fbfe, #fff);
    border: 1px solid var(--rbd-line);
    border-radius: 24px;
    padding: 18px;
}

.ior-rbd-slider-row {
    display: grid;
    gap: 8px;
    margin: 14px 0;
    padding: 14px;
    border: 1px solid #dce9f4;
    border-radius: 18px;
    background: #fff;
}

.ior-rbd-slider-label {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    font-size: 12px;
    color: var(--rbd-muted);
}

.ior-rbd-slider-label strong {
    color: var(--rbd-navy);
    font-size: 13px;
}

.ior-rbd-shell input[type="range"] {
    width: 100%;
    accent-color: var(--rbd-blue);
}

.ior-rbd-benefit-box {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 14px 0;
}

.ior-rbd-benefit-box div {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 18px;
    padding: 14px;
}

.ior-rbd-benefit-box span {
    display: block;
    color: var(--rbd-muted);
    font-size: 11px;
    margin-bottom: 7px;
}

.ior-rbd-benefit-box strong {
    color: var(--rbd-navy);
    font-size: 22px;
}

.ior-rbd-burndown-layout {
    display: grid;
    grid-template-columns: 1.55fr .9fr;
    gap: 16px;
}

.ior-rbd-chart-card {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 24px;
    padding: 18px;
    min-width: 0;
}

.ior-rbd-chart-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.ior-rbd-chart-toolbar select {
    min-width: 240px;
}

.ior-rbd-chart-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 18px;
    border: 1px solid #dce9f4;
    background: linear-gradient(180deg, #ffffff, #f8fbfe);
}

.ior-rbd-chart-wrap canvas {
    display: block;
    width: 100%;
    height: 420px;
    cursor: grab;
}

.ior-rbd-chart-wrap canvas:active {
    cursor: grabbing;
}

.ior-rbd-timeline {
    display: grid;
    gap: 8px;
    max-height: 310px;
    overflow: auto;
    padding-right: 4px;
}

.ior-rbd-time-row {
    display: grid;
    grid-template-columns: 86px 1fr 54px;
    gap: 8px;
    align-items: center;
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 14px;
    padding: 10px;
    font-size: 12px;
}

.ior-rbd-mini-bar {
    height: 8px;
    border-radius: 999px;
    background: #e5edf5;
    overflow: hidden;
}

.ior-rbd-mini-bar span {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #0b5d8f, #0e8b5f);
}

.ior-rbd-report-panel textarea,
.ior-rbd-field textarea,
.ior-rbd-field input,
.ior-rbd-field select,
.ior-rbd-shell input[type="text"],
.ior-rbd-shell input[type="date"],
.ior-rbd-shell input[type="number"],
.ior-rbd-shell select,
.ior-rbd-shell textarea {
    width: 100%;
    border: 1px solid #cbdcea;
    background: #fff;
    border-radius: 14px;
    padding: 11px 12px;
    color: var(--rbd-text);
    font-size: 13px;
    min-height: 42px;
}

.ior-rbd-field textarea,
.ior-rbd-report-panel textarea {
    min-height: 120px;
    resize: vertical;
}

.ior-rbd-field label {
    display: block;
    margin-bottom: 6px;
    font-weight: 700;
    color: var(--rbd-navy);
    font-size: 12px;
}

.ior-rbd-field small {
    display: block;
    color: var(--rbd-muted);
    font-size: 11px;
    margin-top: 5px;
}

.ior-rbd-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 13px;
}

.ior-rbd-form-grid .full {
    grid-column: 1 / -1;
}

.ior-rbd-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(6, 42, 68, .58);
    z-index: 99999;
    display: grid;
    place-items: center;
    padding: 24px;
}

.ior-rbd-modal {
    width: min(940px, 100%);
    max-height: min(88vh, 900px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 28px;
    box-shadow: 0 30px 80px rgba(3, 24, 40, .34);
}

.ior-rbd-modal.small {
    width: min(680px, 100%);
}

.ior-rbd-modal-header {
    padding: 20px 22px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    border-bottom: 1px solid var(--rbd-line);
    background: linear-gradient(180deg, #f7fbfe, #fff);
}

.ior-rbd-modal-header h2 {
    margin: 0 0 5px;
    color: var(--rbd-navy);
    font-size: 22px;
}

.ior-rbd-modal-header p {
    margin: 0;
    color: var(--rbd-muted);
    font-size: 13px;
    line-height: 1.5;
}

.ior-rbd-modal-body {
    padding: 20px 22px;
    overflow: auto;
}

.ior-rbd-modal-footer {
    padding: 16px 22px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    border-top: 1px solid var(--rbd-line);
    background: #f7fbfe;
}

.ior-rbd-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 8px;
}

.ior-rbd-table th {
    text-align: left;
    color: var(--rbd-muted);
    font-size: 11px;
    padding: 0 8px;
}

.ior-rbd-table td {
    background: #fff;
    border-top: 1px solid var(--rbd-line);
    border-bottom: 1px solid var(--rbd-line);
    padding: 8px;
    vertical-align: top;
}

.ior-rbd-table td:first-child {
    border-left: 1px solid var(--rbd-line);
    border-radius: 14px 0 0 14px;
}

.ior-rbd-table td:last-child {
    border-right: 1px solid var(--rbd-line);
    border-radius: 0 14px 14px 0;
}

.ior-rbd-disclaimer {
    margin-top: 16px;
    border-radius: 18px;
    border: 1px solid #ffe0a3;
    background: #fff8e9;
    color: #735000;
    padding: 14px;
    font-size: 12px;
    line-height: 1.5;
}

.ior-rbd-hidden-file {
    display: none !important;
}

.ior-rbd-admin-wrap {
    --rbd-navy: #062a44;
    --rbd-blue: #0c5f95;
    --rbd-line: #d7e4ef;
    --rbd-soft: #f5f9fd;
    --rbd-muted: #63788b;
    max-width: 1220px;
}

.ior-rbd-admin-hero {
    margin-top: 18px;
    border-radius: 24px;
    padding: 26px;
    background: linear-gradient(135deg, #062a44, #0c5f95);
    color: #fff;
    display: flex;
    justify-content: space-between;
    gap: 22px;
    align-items: stretch;
}

.ior-rbd-admin-hero h1 {
    color: #fff;
    margin: 0 0 8px;
    font-size: 34px;
}

.ior-rbd-admin-hero p {
    margin: 0;
    color: rgba(255,255,255,.88);
    max-width: 760px;
    line-height: 1.55;
}

.ior-rbd-admin-version {
    min-width: 170px;
    border-radius: 18px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    padding: 16px;
    display: grid;
    align-content: center;
}

.ior-rbd-admin-version span,
.ior-rbd-admin-version small {
    color: rgba(255,255,255,.75);
}

.ior-rbd-admin-version strong {
    display: block;
    font-size: 30px;
    color: #fff;
}

.ior-rbd-admin-tabs {
    display: flex;
    gap: 8px;
    margin: 16px 0;
}

.ior-rbd-admin-tabs a {
    text-decoration: none;
    border: 1px solid var(--rbd-line);
    background: #fff;
    border-radius: 999px;
    padding: 10px 14px;
    color: var(--rbd-navy);
    font-weight: 700;
}

.ior-rbd-admin-tabs a.is-active {
    background: var(--rbd-navy);
    color: #fff;
    border-color: var(--rbd-navy);
}

.ior-rbd-admin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.ior-rbd-admin-card {
    background: #fff;
    border: 1px solid var(--rbd-line);
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 8px 26px rgba(6, 42, 68, .06);
}

.ior-rbd-admin-card-wide {
    grid-column: 1 / -1;
}

.ior-rbd-admin-card h2 {
    margin: 0 0 10px;
    color: var(--rbd-navy);
}

.ior-rbd-admin-card p,
.ior-rbd-admin-card li {
    color: #4e6375;
    line-height: 1.55;
}

.ior-rbd-admin-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.ior-rbd-admin-steps div {
    border: 1px solid var(--rbd-line);
    border-radius: 18px;
    background: var(--rbd-soft);
    padding: 16px;
}

.ior-rbd-admin-steps strong {
    display: block;
    color: var(--rbd-blue);
    margin-bottom: 6px;
}

.ior-rbd-admin-steps span {
    color: #4e6375;
}

.ior-rbd-shortcode-box {
    display: inline-block;
    border-radius: 14px;
    background: #eef6fc;
    color: var(--rbd-navy);
    padding: 14px 18px;
    font-family: Consolas, Monaco, monospace;
    font-size: 18px;
    margin: 8px 0 12px;
}

@media (max-width: 980px) {
    .ior-rbd-hero-grid,
    .ior-rbd-register-layout,
    .ior-rbd-impact-layout,
    .ior-rbd-burndown-layout {
        grid-template-columns: 1fr;
    }
    .ior-rbd-step-nav,
    .ior-rbd-card-grid,
    .ior-rbd-card-grid.two,
    .ior-rbd-admin-steps,
    .ior-rbd-admin-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 680px) {
    .ior-rbd-shell {
        padding: 12px;
    }
    .ior-rbd-hero,
    .ior-rbd-workspace {
        border-radius: 20px;
        padding: 18px;
    }
    .ior-rbd-step-nav,
    .ior-rbd-card-grid,
    .ior-rbd-card-grid.two,
    .ior-rbd-stat-grid,
    .ior-rbd-benefit-box,
    .ior-rbd-form-grid,
    .ior-rbd-admin-steps,
    .ior-rbd-admin-grid {
        grid-template-columns: 1fr;
    }
    .ior-rbd-workspace-header,
    .ior-rbd-admin-hero {
        flex-direction: column;
    }
    .ior-rbd-modal-backdrop {
        padding: 10px;
    }
}

/* v3.0.0 professional front-end polish and hardening against theme resets */
.ior-rbd-shell,
.ior-rbd-shell * {
    font-family: Verdana, Geneva, sans-serif !important;
    letter-spacing: normal;
}

.ior-rbd-shell {
    max-width: min(1420px, calc(100vw - 48px));
    width: 100%;
    margin: 26px auto 42px;
    padding: 0;
    color: var(--rbd-text, #173047);
}

.ior-rbd-app {
    background: linear-gradient(180deg, rgba(238, 247, 255, .96), #ffffff 38%, #f7fbff 100%);
    border: 1px solid #1d64ad;
    border-radius: 26px;
    box-shadow: 0 30px 80px rgba(6, 42, 68, .16);
    overflow: hidden;
}

.ior-rbd-product-frame {
    padding: 28px 28px 22px;
    background:
        radial-gradient(circle at 5% 10%, rgba(12, 95, 149, .14), transparent 32%),
        radial-gradient(circle at 92% 16%, rgba(14, 139, 95, .16), transparent 30%),
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,251,255,.96));
}

.ior-rbd-hero {
    border: 1px solid #0f5594;
    border-radius: 10px;
    padding: 28px;
    background: linear-gradient(128deg, #1253af 0%, #0d5fa0 50%, #07956f 100%);
    box-shadow: 0 16px 35px rgba(6, 42, 68, .16);
}

.ior-rbd-hero-grid {
    grid-template-columns: minmax(0, 1.35fr) minmax(360px, .85fr);
    min-height: 250px;
}

.ior-rbd-hero-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ior-rbd-kicker {
    color: rgba(255,255,255,.82);
    font-size: 12px;
    letter-spacing: .12em !important;
}

.ior-rbd-hero h1 {
    max-width: 780px;
    font-size: clamp(34px, 4.2vw, 58px);
    font-weight: 800;
    letter-spacing: -.035em !important;
    text-shadow: 0 2px 8px rgba(0,0,0,.1);
}

.ior-rbd-hero-lead {
    max-width: 780px;
    font-size: 17px !important;
    font-weight: 600;
    color: rgba(255,255,255,.93) !important;
}

.ior-rbd-hero-visual {
    position: relative;
    min-height: 250px;
    display: grid;
    align-items: center;
}

.ior-rbd-screen-card {
    position: relative;
    z-index: 2;
    background: rgba(255,255,255,.94);
    border: 1px solid rgba(255,255,255,.72);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 24px 52px rgba(0,0,0,.18);
    transform: rotate(.4deg);
}

.ior-rbd-screen-head {
    display: flex;
    align-items: center;
    gap: 7px;
    color: #062a44;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .07em !important;
    margin-bottom: 14px;
}

.ior-rbd-screen-head span {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #dce8f3;
}

.ior-rbd-screen-head span:nth-child(1) { background: #f2b2a7; }
.ior-rbd-screen-head span:nth-child(2) { background: #f7d36d; }
.ior-rbd-screen-head span:nth-child(3) { background: #8fd2b2; }
.ior-rbd-screen-head strong { margin-left: auto; }

.ior-rbd-mini-chart {
    height: 126px;
    border: 1px solid #d9e8f5;
    border-radius: 18px;
    background:
      linear-gradient(180deg, rgba(180,49,49,.10), rgba(200,135,0,.09) 48%, rgba(14,139,95,.10)),
      repeating-linear-gradient(0deg, transparent 0 24px, rgba(6,42,68,.08) 25px 26px);
    display: flex;
    align-items: end;
    gap: 10px;
    padding: 16px 18px;
}

.ior-rbd-mini-chart span {
    flex: 1;
    border-radius: 999px 999px 8px 8px;
    background: linear-gradient(180deg, #155fb0, #0e8b5f);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.45);
}

.ior-rbd-mini-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 12px;
}

.ior-rbd-mini-metrics div,
.ior-rbd-floating-card {
    background: #f3f8fd;
    border: 1px solid #d9e8f5;
    border-radius: 16px;
    padding: 10px;
    text-align: center;
}

.ior-rbd-mini-metrics strong,
.ior-rbd-floating-card strong {
    display: block;
    color: #062a44;
    font-size: 24px;
    line-height: 1;
}

.ior-rbd-mini-metrics small,
.ior-rbd-floating-card span {
    display: block;
    color: #60778a;
    font-size: 11px;
    margin-top: 4px;
}

.ior-rbd-floating-card {
    position: absolute;
    z-index: 3;
    width: 132px;
    box-shadow: 0 12px 26px rgba(6,42,68,.14);
}

.ior-rbd-floating-card.one { top: 10px; right: -8px; }
.ior-rbd-floating-card.two { bottom: 8px; left: -12px; }

.ior-rbd-workshop-card {
    margin-top: 24px;
    background: rgba(255,255,255,.92);
    border: 1px solid #2f70b7;
    border-radius: 10px;
    padding: 24px 26px;
    box-shadow: 0 12px 30px rgba(6,42,68,.08);
}

.ior-rbd-workshop-title {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
}

.ior-rbd-section-icon {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: #eaf6ff;
    color: #0c5f95;
    font-size: 14px;
}

.ior-rbd-workshop-title h2 {
    margin: 0 0 6px;
    color: #062a44;
    font-size: 23px;
    font-weight: 700;
}

.ior-rbd-workshop-title p {
    margin: 0;
    color: #63788b;
    font-size: 14px;
}

.ior-rbd-workshop-fields {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.ior-rbd-workshop-card label,
.ior-rbd-objective {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0;
    font-weight: 700;
    color: #062a44;
    font-size: 13px;
}

.ior-rbd-workshop-card input,
.ior-rbd-workshop-card textarea {
    width: 100%;
    border: 1px solid #9bc4e7;
    border-radius: 10px;
    padding: 12px 13px;
    background: #ffffff;
    color: #173047;
    font-size: 14px;
    outline: none;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.55);
}

.ior-rbd-workshop-card input:focus,
.ior-rbd-workshop-card textarea:focus {
    border-color: #0c5f95;
    box-shadow: 0 0 0 3px rgba(12,95,149,.14);
}

.ior-rbd-objective {
    margin-top: 14px;
}

.ior-rbd-objective textarea {
    min-height: 74px;
    resize: vertical;
}

.ior-rbd-step-nav {
    margin-top: 24px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ior-rbd-step-card {
    border-radius: 10px;
    border: 1px solid #b9d5ee;
    background: linear-gradient(180deg, #ffffff, #f7fbff);
    min-height: 178px;
    box-shadow: 0 10px 22px rgba(6,42,68,.07);
}

.ior-rbd-step-card.is-active {
    border-color: #0c5f95;
    box-shadow: 0 16px 34px rgba(12,95,149,.20);
    transform: translateY(-2px);
}

.ior-rbd-step-card h3 {
    font-size: 19px;
    font-weight: 700;
    color: #062a44;
}

.ior-rbd-step-no {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: #0c5f95;
    color: #fff;
    display: inline-grid;
    place-items: center;
    font-weight: 800;
}

.ior-rbd-workspace {
    padding: 28px;
    background: #ffffff;
}

.ior-rbd-workspace-header,
.ior-rbd-panel,
.ior-rbd-info-card,
.ior-rbd-register-summary .ior-rbd-panel,
.ior-rbd-action-card,
.ior-rbd-report-card,
.ior-rbd-burn-chart-card {
    border-radius: 10px;
}

.ior-rbd-workspace-header {
    border: 1px solid #b9d5ee;
    background: linear-gradient(180deg, #f6fbff, #ffffff);
    padding: 22px 24px;
    box-shadow: 0 10px 24px rgba(6,42,68,.06);
}

.ior-rbd-workspace-header h2 {
    color: #062a44;
    font-size: 27px;
    font-weight: 700;
    margin-bottom: 8px;
}

.ior-rbd-workspace-header p {
    font-size: 14px;
    color: #536b7e;
}

.ior-rbd-btn,
.ior-rbd-shell button.ior-rbd-btn,
.ior-rbd-shell a.ior-rbd-btn {
    border-radius: 9px;
    border: 1px solid rgba(12,95,149,.25);
    padding: 11px 15px;
    font-weight: 800;
    font-size: 13px;
    line-height: 1.2;
    cursor: pointer;
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.ior-rbd-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(6,42,68,.12);
}

.ior-rbd-btn-light {
    background: #ffffff;
    color: #064875;
    border-color: #ffffff;
}

.ior-rbd-btn-ghost {
    background: rgba(255,255,255,.12);
    color: #ffffff;
    border-color: rgba(255,255,255,.55);
}

.ior-rbd-btn-primary {
    background: #0c5f95;
    color: #ffffff;
}

.ior-rbd-btn-dark {
    background: #062a44;
    color: #ffffff;
}

.ior-rbd-btn-soft {
    background: #eaf6ff;
    color: #064875;
}

.ior-rbd-card-grid,
.ior-rbd-register-layout,
.ior-rbd-impact-layout,
.ior-rbd-burn-layout {
    gap: 18px;
}

.ior-rbd-info-card,
.ior-rbd-panel,
.ior-rbd-action-card,
.ior-rbd-risk-card,
.ior-rbd-report-card,
.ior-rbd-burn-chart-card {
    border: 1px solid #d7e4ef;
    background: #ffffff;
    box-shadow: 0 10px 26px rgba(6,42,68,.06);
}

.ior-rbd-form-grid input,
.ior-rbd-form-grid select,
.ior-rbd-form-grid textarea,
.ior-rbd-field input,
.ior-rbd-field select,
.ior-rbd-field textarea {
    border-radius: 10px;
    border: 1px solid #aacbe8;
    padding: 12px 13px;
    background: #fff;
}

.ior-rbd-modal {
    border-radius: 18px;
    border: 1px solid #b9d5ee;
    box-shadow: 0 30px 80px rgba(0,0,0,.25);
}

.ior-rbd-modal-header {
    background: linear-gradient(135deg, #062a44, #0c5f95);
    color: #ffffff;
    border-radius: 16px 16px 0 0;
}

.ior-rbd-modal-header h2,
.ior-rbd-modal-header p {
    color: #ffffff;
}

.ior-rbd-table th {
    background: #062a44;
    color: #ffffff;
}

.ior-rbd-disclaimer {
    margin: 0 28px 28px;
}

@media (max-width: 1120px) {
    .ior-rbd-hero-grid,
    .ior-rbd-register-layout,
    .ior-rbd-impact-layout,
    .ior-rbd-burn-layout {
        grid-template-columns: 1fr;
    }
    .ior-rbd-workshop-fields,
    .ior-rbd-step-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .ior-rbd-hero-visual {
        max-width: 560px;
    }
}

@media (max-width: 720px) {
    .ior-rbd-shell {
        max-width: calc(100vw - 18px);
        margin-top: 12px;
    }
    .ior-rbd-product-frame,
    .ior-rbd-workspace {
        padding: 14px;
    }
    .ior-rbd-hero,
    .ior-rbd-workshop-card {
        padding: 18px;
    }
    .ior-rbd-workshop-fields,
    .ior-rbd-step-nav {
        grid-template-columns: 1fr;
    }
}

@media print {
    .ior-rbd-product-frame,
    .ior-rbd-step-nav,
    .no-print {
        display: none !important;
    }
    .ior-rbd-app {
        border: none;
        box-shadow: none;
    }
    .ior-rbd-shell {
        max-width: 100%;
    }
}


/* v3.1.0 hero/admin activity refinements */
.ior-rbd-hero-copy {
    padding-top: 0;
}

.ior-rbd-hero h1 {
    color: #ffffff !important;
    margin-top: 0 !important;
}

.ior-rbd-hero-lead {
    font-weight: 400 !important;
}

.ior-rbd-hero-actions {
    margin-top: 24px;
}

.ior-rbd-admin-actions-modal {
    display: grid;
    gap: 14px;
}

.ior-rbd-admin-action-card {
    border: 1px solid #d7e4ef;
    border-radius: 14px;
    padding: 16px;
    background: linear-gradient(180deg, #ffffff, #f7fbff);
    box-shadow: 0 8px 22px rgba(6,42,68,.06);
}

.ior-rbd-admin-action-card h3 {
    margin: 0 0 8px;
    color: #062a44;
    font-size: 16px;
}

.ior-rbd-admin-action-card p {
    margin: 0 0 12px;
    color: #63788b;
    font-size: 13px;
    line-height: 1.55;
}

/* v3.2.0 hero visual card elevation and spacing */
.ior-rbd-hero-visual {
    min-height: 285px;
    padding: 18px 12px;
}

.ior-rbd-floating-card {
    z-index: 6;
    width: 148px;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid rgba(255,255,255,.92);
    box-shadow: 0 22px 42px rgba(6,42,68,.28), 0 4px 10px rgba(6,42,68,.12);
}

.ior-rbd-floating-card.one {
    top: -36px;
    right: 12px;
}

.ior-rbd-floating-card.two {
    bottom: -10px;
    left: 18px;
}

.ior-rbd-screen-card {
    margin: 12px 22px;
}

@media (max-width: 1120px) {
    .ior-rbd-floating-card.one { top: -18px; right: 8px; }
    .ior-rbd-floating-card.two { bottom: 0; left: 8px; }
}


/* v3.3.0: lift the residual risk callout above the screen title text. */


/* v3.4.0 admin modal and workshop setup polish */
.ior-rbd-shell .ior-rbd-modal .ior-rbd-modal-header,
.ior-rbd-modal .ior-rbd-modal-header {
    background: linear-gradient(135deg, #062a44 0%, #0c5f95 100%) !important;
    color: #ffffff !important;
    border-bottom: 0 !important;
}

.ior-rbd-shell .ior-rbd-modal .ior-rbd-modal-header h2,
.ior-rbd-shell .ior-rbd-modal .ior-rbd-modal-header p,
.ior-rbd-modal .ior-rbd-modal-header h2,
.ior-rbd-modal .ior-rbd-modal-header p {
    color: #ffffff !important;
}

.ior-rbd-shell .ior-rbd-modal .ior-rbd-modal-header h2,
.ior-rbd-modal .ior-rbd-modal-header h2 {
    font-weight: 700 !important;
    letter-spacing: -.015em !important;
}

.ior-rbd-shell .ior-rbd-modal .ior-rbd-modal-header p,
.ior-rbd-modal .ior-rbd-modal-header p {
    font-weight: 400 !important;
    opacity: .92;
}

.ior-rbd-workshop-card {
    margin-top: 18px !important;
    background:
      linear-gradient(180deg, rgba(255,255,255,.97), rgba(247,251,255,.97)) !important;
    border: 1px solid #c7ddef !important;
    border-radius: 18px !important;
    padding: 22px 24px 24px !important;
    box-shadow: 0 14px 30px rgba(6,42,68,.07) !important;
}

.ior-rbd-workshop-title {
    display: block !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #e1edf7 !important;
}

.ior-rbd-workshop-title h2 {
    margin: 0 0 5px !important;
    color: #062a44 !important;
    font-size: 20px !important;
    line-height: 1.25 !important;
    font-weight: 700 !important;
}

.ior-rbd-workshop-title p {
    margin: 0 !important;
    color: #60778a !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    font-weight: 400 !important;
}

.ior-rbd-section-icon {
    display: none !important;
}

.ior-rbd-workshop-fields {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.ior-rbd-workshop-card label,
.ior-rbd-objective {
    gap: 6px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: #24445f !important;
    letter-spacing: 0 !important;
}

.ior-rbd-workshop-card label > span,
.ior-rbd-objective > span {
    font-size: 12px !important;
    font-weight: 500 !important;
    color: #24445f !important;
}

.ior-rbd-workshop-card input,
.ior-rbd-workshop-card textarea {
    min-height: 40px !important;
    border: 1px solid #c5dcf0 !important;
    border-radius: 10px !important;
    padding: 9px 11px !important;
    background: #ffffff !important;
    color: #173047 !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    font-weight: 400 !important;
    box-shadow: 0 1px 2px rgba(6,42,68,.04) !important;
}

.ior-rbd-workshop-card input::placeholder,
.ior-rbd-workshop-card textarea::placeholder {
    color: #8fa1b1 !important;
    font-weight: 400 !important;
}

.ior-rbd-objective {
    margin-top: 12px !important;
}

.ior-rbd-objective textarea {
    min-height: 64px !important;
}

@media (max-width: 1120px) {
    .ior-rbd-workshop-fields {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    .ior-rbd-workshop-card {
        padding: 18px !important;
    }
    .ior-rbd-workshop-fields {
        grid-template-columns: 1fr !important;
    }
}


/* v3.5.0 step navigation refinement */
.ior-rbd-step-top {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    width: 100% !important;
    margin-bottom: 14px !important;
}

.ior-rbd-step-no {
    flex: 0 0 auto !important;
    margin: 0 !important;
    align-self: flex-start !important;
}

.ior-rbd-step-setup {
    width: auto !important;
    min-width: 76px !important;
    padding: 0 13px !important;
    border-radius: 9px !important;
    letter-spacing: .02em !important;
}

.ior-rbd-step-top .ior-rbd-pill {
    margin-left: auto !important;
    align-self: flex-start !important;
}


/* v3.7.0 pathway card alignment refinement */
#ior-risk-burn-down-root .ior-rbd-step-card {
    position: relative !important;
    padding: 74px 16px 17px !important;
    min-height: 176px !important;
}

#ior-risk-burn-down-root .ior-rbd-step-top {
    position: absolute !important;
    top: 18px !important;
    left: 16px !important;
    right: 16px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin: 0 !important;
    gap: 10px !important;
}

#ior-risk-burn-down-root .ior-rbd-step-no,
#ior-risk-burn-down-root .ior-rbd-step-setup {
    height: 36px !important;
    min-height: 36px !important;
    display: inline-grid !important;
    place-items: center !important;
    line-height: 1 !important;
    margin: 0 !important;
    align-self: center !important;
}

#ior-risk-burn-down-root .ior-rbd-step-no {
    width: 36px !important;
    min-width: 36px !important;
}

#ior-risk-burn-down-root .ior-rbd-step-setup {
    width: auto !important;
    min-width: 76px !important;
    padding: 0 13px !important;
}

#ior-risk-burn-down-root .ior-rbd-step-top .ior-rbd-pill {
    height: 32px !important;
    min-height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    align-self: center !important;
    line-height: 1 !important;
}

#ior-risk-burn-down-root .ior-rbd-step-card h3 {
    margin-top: 0 !important;
}


/* v3.8.0: make Low matrix values visibly green and allow inline band border colours to show. */
.ior-rbd-app .ior-rbd-matrix-cell {
  border-width: 1px !important;
  border-style: solid !important;
}


/* v3.9.0: lock pathway card headers inside each card so status text never clips or bleeds past the edge. */
#ior-risk-burn-down-root .ior-rbd-step-nav {
  align-items: stretch !important;
}

#ior-risk-burn-down-root .ior-rbd-step-card {
  box-sizing: border-box !important;
  overflow: hidden !important;
  padding: 76px 16px 18px !important;
}

#ior-risk-burn-down-root .ior-rbd-step-top {
  box-sizing: border-box !important;
  position: absolute !important;
  top: 17px !important;
  left: 16px !important;
  right: 16px !important;
  width: auto !important;
  max-width: calc(100% - 32px) !important;
  height: 38px !important;
  display: grid !important;
  grid-template-columns: minmax(0, max-content) 66px !important;
  justify-content: space-between !important;
  align-items: center !important;
  column-gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

#ior-risk-burn-down-root .ior-rbd-step-no,
#ior-risk-burn-down-root .ior-rbd-step-setup {
  box-sizing: border-box !important;
  justify-self: start !important;
  flex: none !important;
}

#ior-risk-burn-down-root .ior-rbd-step-top .ior-rbd-pill {
  box-sizing: border-box !important;
  justify-self: end !important;
  flex: 0 0 66px !important;
  width: 66px !important;
  min-width: 66px !important;
  max-width: 66px !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 10px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: visible !important;
  line-height: 1 !important;
}

@media (max-width: 720px) {
  #ior-risk-burn-down-root .ior-rbd-step-top {
    grid-template-columns: minmax(0, max-content) 66px !important;
  }
}


/* v3.10.0: matrix cells now have a consistent border treatment across every rating band. The colour still follows the rating. */
#ior-risk-burn-down-root .ior-rbd-matrix-cell,
.ior-rbd-app .ior-rbd-matrix-cell {
  border-width: 1px !important;
  border-style: solid !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.28) !important;
}

/* v3.11.0: explicit rating cell classes so borders cannot inherit the wrong band colour. */
#ior-risk-burn-down-root .ior-rbd-matrix-cell,
.ior-rbd-app .ior-rbd-matrix-cell {
  border-width: 1px !important;
  border-style: solid !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.32) !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-low,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-low {
  background: #d7f8e2 !important;
  border-color: #57b86f !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-medium,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-medium {
  background: #fff2bf !important;
  border-color: #e0b323 !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-high,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-high {
  background: #ffd7b5 !important;
  border-color: #d87922 !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-critical,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-critical {
  background: #f4b6b6 !important;
  border-color: #d45c5c !important;
}


/* v3.12.0: hero metric rating labels and Overview Information field polish. */
#ior-risk-burn-down-root .ior-rbd-mini-metrics div,
.ior-rbd-app .ior-rbd-mini-metrics div {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 86px !important;
}

#ior-risk-burn-down-root .ior-rbd-mini-metrics .ior-rbd-metric-rating,
.ior-rbd-app .ior-rbd-mini-metrics .ior-rbd-metric-rating {
  display: block !important;
  color: #0c5f95 !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  margin: 0 0 5px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .045em !important;
  white-space: nowrap !important;
}

#ior-risk-burn-down-root .ior-rbd-workshop-card label > span,
#ior-risk-burn-down-root .ior-rbd-objective > span,
.ior-rbd-app .ior-rbd-workshop-card label > span,
.ior-rbd-app .ior-rbd-objective > span {
  font-weight: 700 !important;
  color: #062a44 !important;
}

#ior-risk-burn-down-root .ior-rbd-workshop-card input,
#ior-risk-burn-down-root .ior-rbd-workshop-card textarea,
.ior-rbd-app .ior-rbd-workshop-card input,
.ior-rbd-app .ior-rbd-workshop-card textarea {
  font-size: 13px !important;
  font-weight: 400 !important;
}


/* v3.13.0: hard-lock matrix cell colours and borders. Inline styles are also applied by JS, but these rules protect against theme overrides and stale browser data. */
#ior-risk-burn-down-root .ior-rbd-matrix-cell,
.ior-rbd-app .ior-rbd-matrix-cell {
  border-width: 2px !important;
  border-style: solid !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-low,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-low {
  background: #d7f8e2 !important;
  border-color: #57b86f !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-medium,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-medium {
  background: #fff2bf !important;
  border-color: #d6ad00 !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-high,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-high {
  background: #ffd7b5 !important;
  border-color: #d97706 !important;
}

#ior-risk-burn-down-root .ior-rbd-matrix-cell.ior-rbd-rating-critical,
.ior-rbd-app .ior-rbd-matrix-cell.ior-rbd-rating-critical {
  background: #f4b6b6 !important;
  border-color: #c53030 !important;
}

/* v4.0.0: single-risk workflow, saved-risk loader and refined hero action placement. */
#ior-risk-burn-down-root .ior-rbd-hero-actions-split,
.ior-rbd-app .ior-rbd-hero-actions-split {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  max-width: 560px !important;
}

#ior-risk-burn-down-root .ior-rbd-admin-hero-btn,
.ior-rbd-app .ior-rbd-admin-hero-btn {
  margin-left: auto !important;
}

#ior-risk-burn-down-root .ior-rbd-single-risk-layout,
.ior-rbd-app .ior-rbd-single-risk-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.55fr) minmax(300px, .85fr) !important;
  gap: 16px !important;
  align-items: start !important;
}

#ior-risk-burn-down-root .ior-rbd-single-risk-card,
.ior-rbd-app .ior-rbd-single-risk-card {
  border-radius: 22px !important;
  padding: 18px !important;
  box-shadow: 0 16px 34px rgba(6,42,68,.10) !important;
  background: linear-gradient(180deg, #ffffff, #f8fbff) !important;
}

#ior-risk-burn-down-root .ior-rbd-single-risk-empty,
.ior-rbd-app .ior-rbd-single-risk-empty {
  padding: 22px !important;
  border-radius: 22px !important;
}

#ior-risk-burn-down-root .ior-rbd-section-label,
.ior-rbd-app .ior-rbd-section-label {
  display: inline-block !important;
  margin-bottom: 5px !important;
  color: #0c5f95 !important;
  font-size: 11px !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  font-weight: 800 !important;
}

#ior-risk-burn-down-root .ior-rbd-modal.medium,
.ior-rbd-app .ior-rbd-modal.medium {
  max-width: 860px !important;
}

#ior-risk-burn-down-root .ior-rbd-risk-library-modal,
.ior-rbd-app .ior-rbd-risk-library-modal {
  display: grid !important;
  gap: 14px !important;
}

#ior-risk-burn-down-root .ior-rbd-library-save-card,
.ior-rbd-app .ior-rbd-library-save-card {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 16px !important;
  border-radius: 16px !important;
  border: 1px solid #c7ddef !important;
  background: linear-gradient(135deg, #f8fbff, #eef7ff) !important;
}

#ior-risk-burn-down-root .ior-rbd-library-save-card h3,
.ior-rbd-app .ior-rbd-library-save-card h3 {
  margin: 0 0 5px !important;
  color: #062a44 !important;
  font-size: 16px !important;
}

#ior-risk-burn-down-root .ior-rbd-library-save-card p,
.ior-rbd-app .ior-rbd-library-save-card p {
  margin: 0 !important;
  color: #63788b !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

#ior-risk-burn-down-root .ior-rbd-library-list,
.ior-rbd-app .ior-rbd-library-list {
  display: grid !important;
  gap: 12px !important;
}

#ior-risk-burn-down-root .ior-rbd-library-card,
.ior-rbd-app .ior-rbd-library-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 16px !important;
  border: 1px solid #d7e4ef !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  box-shadow: 0 10px 24px rgba(6,42,68,.06) !important;
}

#ior-risk-burn-down-root .ior-rbd-library-card h3,
.ior-rbd-app .ior-rbd-library-card h3 {
  margin: 0 0 5px !important;
  color: #062a44 !important;
  font-size: 16px !important;
}

#ior-risk-burn-down-root .ior-rbd-library-card p,
.ior-rbd-app .ior-rbd-library-card p {
  margin: 0 !important;
  color: #63788b !important;
  font-size: 12px !important;
}

#ior-risk-burn-down-root .ior-rbd-library-card-actions,
.ior-rbd-app .ior-rbd-library-card-actions {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
}

#ior-risk-burn-down-root .ior-rbd-chart-risk-title,
.ior-rbd-app .ior-rbd-chart-risk-title {
  display: grid !important;
  gap: 3px !important;
}

#ior-risk-burn-down-root .ior-rbd-chart-risk-title span,
.ior-rbd-app .ior-rbd-chart-risk-title span {
  color: #63788b !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  font-weight: 800 !important;
}

#ior-risk-burn-down-root .ior-rbd-chart-risk-title strong,
.ior-rbd-app .ior-rbd-chart-risk-title strong {
  color: #062a44 !important;
  font-size: 15px !important;
}

@media (max-width: 980px) {
  #ior-risk-burn-down-root .ior-rbd-single-risk-layout,
  .ior-rbd-app .ior-rbd-single-risk-layout {
    grid-template-columns: 1fr !important;
  }
  #ior-risk-burn-down-root .ior-rbd-admin-hero-btn,
  .ior-rbd-app .ior-rbd-admin-hero-btn {
    margin-left: 0 !important;
  }
}

@media (max-width: 720px) {
  #ior-risk-burn-down-root .ior-rbd-library-card,
  .ior-rbd-app .ior-rbd-library-card,
  #ior-risk-burn-down-root .ior-rbd-library-save-card,
  .ior-rbd-app .ior-rbd-library-save-card {
    grid-template-columns: 1fr !important;
    display: grid !important;
  }
  #ior-risk-burn-down-root .ior-rbd-library-card-actions,
  .ior-rbd-app .ior-rbd-library-card-actions {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
  }
}

/* v4.1.0: title labels now use Risk Title where the selected risk name is displayed. */


/* v4.3.0: top-right hero card shows the current loaded risk title rather than a count/static label. */
#ior-risk-burn-down-root .ior-rbd-floating-card.ior-rbd-risk-title-float,
.ior-rbd-app .ior-rbd-floating-card.ior-rbd-risk-title-float {
  width: 210px !important;
  max-width: min(210px, calc(100% - 24px)) !important;
  padding: 11px 14px !important;
}

#ior-risk-burn-down-root .ior-rbd-floating-card.ior-rbd-risk-title-float strong,
.ior-rbd-app .ior-rbd-floating-card.ior-rbd-risk-title-float strong {
  color: #062a44 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 14px !important;
  line-height: 1.18 !important;
  font-weight: 800 !important;
  white-space: normal !important;
}

#ior-risk-burn-down-root .ior-rbd-floating-card.ior-rbd-risk-title-float span,
.ior-rbd-app .ior-rbd-floating-card.ior-rbd-risk-title-float span {
  margin-top: 5px !important;
  color: #60778a !important;
  font-size: 10.5px !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

@media (max-width: 720px) {
  #ior-risk-burn-down-root .ior-rbd-floating-card.ior-rbd-risk-title-float,
  .ior-rbd-app .ior-rbd-floating-card.ior-rbd-risk-title-float {
    width: 180px !important;
  }
}

/* v5.0.0 impact chart and final report workflow */
#ior-risk-burn-down-root .ior-rbd-impact-layout-wide,
.ior-rbd-app .ior-rbd-impact-layout-wide {
    grid-template-columns: .82fr 1.65fr;
    align-items: start;
}

#ior-risk-burn-down-root .ior-rbd-impact-main,
.ior-rbd-app .ior-rbd-impact-main {
    display: grid;
    gap: 16px;
    min-width: 0;
}

#ior-risk-burn-down-root .ior-rbd-impact-chart-card,
.ior-rbd-app .ior-rbd-impact-chart-card {
    box-shadow: 0 16px 38px rgba(6,42,68,.09);
}

#ior-risk-burn-down-root .ior-rbd-benefit-box small,
.ior-rbd-app .ior-rbd-benefit-box small {
    display: block;
    color: #63788b;
    font-size: 11px;
    margin-top: 4px;
}

#ior-risk-burn-down-root .ior-rbd-point-change-strip,
.ior-rbd-app .ior-rbd-point-change-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

#ior-risk-burn-down-root .ior-rbd-point-change-strip span,
.ior-rbd-app .ior-rbd-point-change-strip span {
    border: 1px solid #cfe0ee;
    background: #f4f9fd;
    color: #173047;
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 11px;
    font-weight: 700;
}

#ior-risk-burn-down-root .ior-rbd-final-report,
.ior-rbd-app .ior-rbd-final-report {
    display: grid;
    gap: 16px;
}

#ior-risk-burn-down-root .ior-rbd-report-chart-grid,
.ior-rbd-app .ior-rbd-report-chart-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

#ior-risk-burn-down-root .ior-rbd-report-grid,
.ior-rbd-app .ior-rbd-report-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 16px;
    align-items: start;
}

#ior-risk-burn-down-root .ior-rbd-residual-report-card,
.ior-rbd-app .ior-rbd-residual-report-card {
    display: grid;
    grid-template-columns: 1.25fr .95fr;
    gap: 18px;
    align-items: stretch;
    background: linear-gradient(180deg, #f7fbfe, #ffffff);
}

#ior-risk-burn-down-root .ior-rbd-section-kicker,
.ior-rbd-app .ior-rbd-section-kicker {
    display: block;
    color: #0c5f95;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 11px;
    font-weight: 800;
    margin-bottom: 6px;
}

#ior-risk-burn-down-root .ior-rbd-report-metric-strip,
.ior-rbd-app .ior-rbd-report-metric-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

#ior-risk-burn-down-root .ior-rbd-report-metric-strip div,
.ior-rbd-app .ior-rbd-report-metric-strip div {
    border: 1px solid #d7e4ef;
    border-radius: 14px;
    background: #fff;
    padding: 14px;
}

#ior-risk-burn-down-root .ior-rbd-report-metric-strip span,
.ior-rbd-app .ior-rbd-report-metric-strip span {
    display: block;
    color: #63788b;
    font-size: 11px;
    margin-bottom: 6px;
}

#ior-risk-burn-down-root .ior-rbd-report-metric-strip strong,
.ior-rbd-app .ior-rbd-report-metric-strip strong {
    display: block;
    color: #062a44;
    font-size: 25px;
    line-height: 1;
}

#ior-risk-burn-down-root .ior-rbd-report-metric-strip small,
.ior-rbd-app .ior-rbd-report-metric-strip small {
    display: block;
    color: #63788b;
    font-size: 11px;
    margin-top: 5px;
}

#ior-risk-burn-down-root .ior-rbd-report-action-list,
.ior-rbd-app .ior-rbd-report-action-list,
#ior-risk-burn-down-root .ior-rbd-point-summary-list,
.ior-rbd-app .ior-rbd-point-summary-list {
    display: grid;
    gap: 10px;
}

#ior-risk-burn-down-root .ior-rbd-report-action-list article,
.ior-rbd-app .ior-rbd-report-action-list article,
#ior-risk-burn-down-root .ior-rbd-point-summary-list article,
.ior-rbd-app .ior-rbd-point-summary-list article {
    border: 1px solid #d7e4ef;
    background: #fff;
    border-radius: 14px;
    padding: 12px;
}

#ior-risk-burn-down-root .ior-rbd-report-action-list h4,
.ior-rbd-app .ior-rbd-report-action-list h4 {
    margin: 0 0 4px;
    color: #062a44;
    font-size: 14px;
}

#ior-risk-burn-down-root .ior-rbd-report-action-list p,
.ior-rbd-app .ior-rbd-report-action-list p,
#ior-risk-burn-down-root .ior-rbd-point-summary-list p,
.ior-rbd-app .ior-rbd-point-summary-list p {
    margin: 4px 0;
    color: #536b7e;
    font-size: 12px;
    line-height: 1.45;
}

#ior-risk-burn-down-root .ior-rbd-point-summary-list article > div:first-child,
.ior-rbd-app .ior-rbd-point-summary-list article > div:first-child {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: #062a44;
    font-size: 13px;
}

#ior-risk-burn-down-root .ior-rbd-point-modal-summary,
.ior-rbd-app .ior-rbd-point-modal-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

#ior-risk-burn-down-root .ior-rbd-point-modal-summary div,
.ior-rbd-app .ior-rbd-point-modal-summary div {
    border: 1px solid #d7e4ef;
    border-radius: 12px;
    padding: 12px;
    background: #f8fbfe;
}

#ior-risk-burn-down-root .ior-rbd-point-modal-summary span,
.ior-rbd-app .ior-rbd-point-modal-summary span,
#ior-risk-burn-down-root .ior-rbd-point-modal-summary small,
.ior-rbd-app .ior-rbd-point-modal-summary small {
    display: block;
    color: #63788b;
    font-size: 11px;
}

#ior-risk-burn-down-root .ior-rbd-point-modal-summary strong,
.ior-rbd-app .ior-rbd-point-modal-summary strong {
    display: block;
    color: #062a44;
    font-size: 20px;
    margin: 4px 0;
}

#ior-risk-burn-down-root .ior-rbd-action-checkbox-list,
.ior-rbd-app .ior-rbd-action-checkbox-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    max-height: 260px;
    overflow: auto;
    padding-right: 4px;
}

#ior-risk-burn-down-root .ior-rbd-action-checkbox-list label,
.ior-rbd-app .ior-rbd-action-checkbox-list label {
    display: grid;
    grid-template-columns: 20px 1fr;
    gap: 8px;
    border: 1px solid #d7e4ef;
    border-radius: 12px;
    padding: 10px;
    background: #fff;
    font-weight: 400;
    color: #173047;
}

#ior-risk-burn-down-root .ior-rbd-action-checkbox-list input,
.ior-rbd-app .ior-rbd-action-checkbox-list input {
    width: auto;
    min-height: auto;
    margin-top: 2px;
}

#ior-risk-burn-down-root .ior-rbd-action-checkbox-list small,
.ior-rbd-app .ior-rbd-action-checkbox-list small {
    grid-column: 2;
    color: #63788b;
    font-size: 11px;
    line-height: 1.35;
}

@media (max-width: 920px) {
    #ior-risk-burn-down-root .ior-rbd-impact-layout-wide,
    .ior-rbd-app .ior-rbd-impact-layout-wide,
    #ior-risk-burn-down-root .ior-rbd-report-chart-grid,
    .ior-rbd-app .ior-rbd-report-chart-grid,
    #ior-risk-burn-down-root .ior-rbd-report-grid,
    .ior-rbd-app .ior-rbd-report-grid,
    #ior-risk-burn-down-root .ior-rbd-residual-report-card,
    .ior-rbd-app .ior-rbd-residual-report-card,
    #ior-risk-burn-down-root .ior-rbd-action-checkbox-list,
    .ior-rbd-app .ior-rbd-action-checkbox-list {
        grid-template-columns: 1fr;
    }
}

/* v5.1.0 chart readability and impact editor placement */
#ior-risk-burn-down-root .ior-rbd-action-portfolio-panel,
.ior-rbd-app .ior-rbd-action-portfolio-panel {
    display: grid;
    gap: 14px;
}

#ior-risk-burn-down-root .ior-rbd-action-portfolio-heading,
.ior-rbd-app .ior-rbd-action-portfolio-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 12px;
}

#ior-risk-burn-down-root .ior-rbd-action-portfolio-heading h3,
.ior-rbd-app .ior-rbd-action-portfolio-heading h3 {
    margin: 0 0 6px;
}

#ior-risk-burn-down-root .ior-rbd-action-portfolio-heading p,
.ior-rbd-app .ior-rbd-action-portfolio-heading p {
    margin: 0;
}

#ior-risk-burn-down-root .ior-rbd-chart-heading,
.ior-rbd-app .ior-rbd-chart-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 8px 0 10px;
    padding: 10px 12px;
    border: 1px solid #d7e4ef;
    border-radius: 14px;
    background: #f7fbfe;
    color: #062a44;
}

#ior-risk-burn-down-root .ior-rbd-chart-heading strong,
.ior-rbd-app .ior-rbd-chart-heading strong {
    font-size: 15px;
    line-height: 1.25;
}

#ior-risk-burn-down-root .ior-rbd-chart-heading span,
.ior-rbd-app .ior-rbd-chart-heading span {
    font-size: 16px;
    font-weight: 800;
    white-space: nowrap;
    color: #0c5f95;
}

#ior-risk-burn-down-root .ior-rbd-chart-wrap canvas,
.ior-rbd-app .ior-rbd-chart-wrap canvas {
    height: 460px;
}

#ior-risk-burn-down-root .ior-rbd-impact-editor,
.ior-rbd-app .ior-rbd-impact-editor {
    scroll-margin-top: 24px;
}

@media (max-width: 820px) {
    #ior-risk-burn-down-root .ior-rbd-action-portfolio-heading,
    .ior-rbd-app .ior-rbd-action-portfolio-heading,
    #ior-risk-burn-down-root .ior-rbd-chart-heading,
    .ior-rbd-app .ior-rbd-chart-heading {
        grid-template-columns: 1fr;
        display: grid;
    }

    #ior-risk-burn-down-root .ior-rbd-chart-heading span,
    .ior-rbd-app .ior-rbd-chart-heading span {
        white-space: normal;
    }
}


/* v5.2.0 impact workflow validation and scroll target polish */
#ior-risk-burn-down-root .ior-rbd-validation-message,
.ior-rbd-app .ior-rbd-validation-message {
    grid-column: 1 / -1;
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border: 1px solid #d75b5b;
    border-left: 5px solid #b42323;
    border-radius: 16px;
    background: #fff3f3;
    color: #7a1f1f;
}

#ior-risk-burn-down-root .ior-rbd-validation-message strong,
.ior-rbd-app .ior-rbd-validation-message strong {
    font-size: 13px;
    color: #7a1f1f;
}

#ior-risk-burn-down-root .ior-rbd-validation-message span,
.ior-rbd-app .ior-rbd-validation-message span {
    font-size: 12px;
    line-height: 1.45;
}

#ior-risk-burn-down-root .ior-rbd-required,
.ior-rbd-app .ior-rbd-required {
    display: inline-flex;
    align-items: center;
    margin-left: 6px;
    padding: 2px 7px;
    border-radius: 999px;
    background: #fff3f3;
    color: #9d2525;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .02em;
    text-transform: uppercase;
}
