@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");

:root {
    --bg: #090d12;
    --surface: #0f151d;
    --surface-2: #141c26;
    --surface-3: #1a2531;
    --elevated: #111a24;
    --ink: #eef3f7;
    --muted: #96a3af;
    --faint: #667480;
    --line: #253241;
    --line-soft: rgba(255, 255, 255, .07);
    --accent: #2fbf83;
    --accent-2: #68d5a6;
    --warn: #d7a849;
    --danger: #e06b6b;
    --blue: #6aa9ff;
    --shadow: 0 18px 42px rgba(0, 0, 0, .34);
    --shadow-soft: 0 10px 24px rgba(0, 0, 0, .18);
    --sidebar: 284px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0 !important;
    min-height: 100vh !important;
    background: var(--bg) !important;
    color: var(--ink) !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: 14px;
    line-height: 1.5;
}

body.rp-font-large {
    font-size: 16px;
}

body.rp-density-compact .rp-shell,
body.rp-density-compact .container,
body.rp-density-compact .rp-container {
    padding-top: 14px !important;
    padding-bottom: 34px !important;
}

body.rp-density-compact .rp-card,
body.rp-density-compact .rp-panel {
    padding: 16px !important;
}

body.rp-density-compact .rp-btn,
body.rp-density-compact .btn,
body.rp-density-compact button {
    min-height: 32px;
    padding: 7px 10px !important;
}

body.rp-theme-light {
    --bg: #eef2f6;
    --surface: #ffffff;
    --surface-2: #f3f6f9;
    --surface-3: #e8edf3;
    --elevated: #ffffff;
    --ink: #17202a;
    --muted: #5d6b7a;
    --faint: #8391a0;
    --line: #cfd8e3;
    --line-soft: rgba(23, 32, 42, .1);
    --shadow: 0 18px 42px rgba(20, 35, 50, .12);
}

body.rp-theme-light .navbar,
body.rp-theme-light .rp-topbar,
body.rp-theme-light .rp-nav-group-items {
    background: #ffffff !important;
}

a {
    color: inherit;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .025) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255, 255, 255, .018) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.85), transparent 72%);
}

.rp-shell,
.container,
.rp-container {
    width: auto !important;
    max-width: none !important;
    margin: 0 0 0 var(--sidebar) !important;
    padding: 22px 28px 56px !important;
    background: transparent !important;
    box-shadow: none !important;
}

.navbar,
.rp-topbar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 50;
    width: var(--sidebar) !important;
    height: 100vh;
    display: flex !important;
    flex-direction: column;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 18px !important;
    margin: 0 !important;
    padding: 18px !important;
    border: 0 !important;
    border-right: 1px solid var(--line) !important;
    border-radius: 0 !important;
    background: #0b1118 !important;
    box-shadow: none !important;
}

.navbar h1,
.rp-brand {
    min-height: 52px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 !important;
    padding: 8px 6px 16px;
    border-bottom: 1px solid var(--line);
    color: var(--ink) !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    text-decoration: none;
}

.rp-brand-mark {
    display: grid;
    place-items: center;
    min-width: 42px;
    height: 42px;
    padding: 0 9px;
    border-radius: 8px;
    background: var(--accent);
    color: #03110b;
    font-size: 12px;
    font-weight: 900;
}

.navbar-right,
.rp-nav {
    display: flex !important;
    flex-direction: column;
    align-items: stretch !important;
    gap: 6px !important;
    width: 100%;
    min-width: 0;
    overflow-y: auto;
    padding-right: 2px;
}

.rp-feature-search {
    display: grid;
    gap: 7px;
    margin: 0 0 8px;
    padding: 9px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.rp-feature-search label {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.rp-feature-search-control {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 6px;
}

.rp-feature-search input {
    width: 100%;
    min-width: 0;
    min-height: 36px;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0b1118;
    color: var(--ink);
    font: inherit;
    font-size: 13px;
}

.rp-nav .rp-feature-search + .rp-feature-search {
    margin-top: -2px;
}

.rp-nav .rp-feature-search button {
    white-space: nowrap;
}

.rp-feature-search input:focus {
    outline: none;
    border-color: rgba(47, 191, 131, .55);
    box-shadow: 0 0 0 3px rgba(47, 191, 131, .12);
}

.rp-feature-search button {
    min-height: 36px;
    padding: 8px 10px !important;
    font-size: 12px !important;
}

.navbar-right span,
.rp-user-pill {
    order: 98;
    display: block;
    margin-top: 10px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    color: var(--muted) !important;
    font-size: 13px;
}

.navbar-right a,
.rp-btn,
.btn,
button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 38px;
    padding: 9px 13px !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    background: var(--accent) !important;
    color: #03110b !important;
    font: inherit !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.15;
    text-decoration: none !important;
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}

.navbar-right a,
.rp-nav .rp-btn {
    justify-content: flex-start !important;
    width: 100%;
    background: transparent !important;
    color: var(--muted) !important;
    border-color: transparent !important;
}

.navbar-right a:hover,
.rp-nav .rp-btn:hover,
.rp-nav .rp-btn.active {
    transform: none !important;
    background: var(--surface-2) !important;
    color: var(--ink) !important;
    border-color: var(--line-soft) !important;
}

.rp-nav-group {
    padding: 0;
    border: 1px solid transparent;
    border-radius: 8px;
    background: transparent;
}

.rp-nav-group[open] {
    border-color: var(--line-soft);
    background: rgba(255, 255, 255, .018);
}

.rp-nav-group summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 36px;
    padding: 9px 10px;
    border-radius: 8px;
    color: #c7d1da;
    cursor: pointer;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
    list-style: none;
}

.rp-nav-group summary::-webkit-details-marker {
    display: none;
}

.rp-nav-group summary::after {
    content: "▾";
    color: var(--faint);
    font-size: 16px;
    line-height: 1;
    transform: rotate(0deg);
    transition: transform .16s ease;
}

.rp-nav-group[open] summary::after {
    transform: rotate(90deg);
}

.rp-nav-group summary:hover {
    background: var(--surface);
    color: var(--ink);
}

.rp-nav-group-items {
    display: grid;
    gap: 4px;
    padding: 0 6px 8px;
}

.rp-nav-group-items .rp-btn {
    min-height: 34px;
    padding-left: 12px !important;
    font-weight: 700 !important;
}

.rp-nav .rp-btn:not(.secondary) {
    background: rgba(47, 191, 131, .12) !important;
    color: var(--accent-2) !important;
    border-color: rgba(47, 191, 131, .24) !important;
}

body.rp-nav-right .navbar,
body.rp-nav-right .rp-topbar {
    inset: 0 0 0 auto;
    border-right: 0 !important;
    border-left: 1px solid var(--line) !important;
}

body.rp-nav-right .rp-shell,
body.rp-nav-right .container,
body.rp-nav-right .rp-container {
    margin: 0 var(--sidebar) 0 0 !important;
}

body.rp-nav-top .navbar,
body.rp-nav-top .rp-topbar,
body.rp-nav-bottom .navbar,
body.rp-nav-bottom .rp-topbar {
    left: 0;
    right: 0;
    width: 100% !important;
    height: auto;
    min-height: 74px;
    flex-direction: row;
    align-items: center !important;
    gap: 14px !important;
    padding: 10px 16px !important;
    border-right: 0 !important;
    background: #0b1118 !important;
}

body.rp-nav-top .navbar,
body.rp-nav-top .rp-topbar {
    inset: 0 0 auto 0;
    border-bottom: 1px solid var(--line) !important;
}

body.rp-nav-bottom .navbar,
body.rp-nav-bottom .rp-topbar {
    inset: auto 0 0 0;
    border-top: 1px solid var(--line) !important;
}

body.rp-nav-top .rp-brand,
body.rp-nav-bottom .rp-brand,
body.rp-nav-top .navbar h1,
body.rp-nav-bottom .navbar h1 {
    width: auto;
    min-width: 192px;
    min-height: 46px;
    padding: 4px 14px 4px 0;
    border-bottom: 0;
    border-right: 1px solid var(--line);
}

body.rp-nav-top .rp-nav,
body.rp-nav-bottom .rp-nav,
body.rp-nav-top .navbar-right,
body.rp-nav-bottom .navbar-right {
    flex: 1;
    flex-direction: row;
    align-items: center !important;
    gap: 8px !important;
    width: auto;
    overflow: visible;
    padding: 0;
}

body.rp-nav-top .rp-nav .rp-btn,
body.rp-nav-bottom .rp-nav .rp-btn,
body.rp-nav-top .navbar-right a,
body.rp-nav-bottom .navbar-right a {
    width: auto;
    white-space: nowrap;
}

body.rp-nav-top .rp-nav-group,
body.rp-nav-bottom .rp-nav-group {
    position: relative;
    min-width: auto;
    border-color: transparent;
    background: transparent;
}

body.rp-nav-top .rp-nav-group[open],
body.rp-nav-bottom .rp-nav-group[open] {
    border-color: transparent;
    background: transparent;
}

body.rp-nav-top .rp-nav-group summary,
body.rp-nav-bottom .rp-nav-group summary {
    min-height: 38px;
    padding: 9px 12px;
    border: 1px solid transparent;
    border-radius: 8px;
    white-space: nowrap;
}

body.rp-nav-top .rp-nav-group summary:hover,
body.rp-nav-bottom .rp-nav-group summary:hover,
body.rp-nav-top .rp-nav-group[open] summary,
body.rp-nav-bottom .rp-nav-group[open] summary {
    background: var(--surface-2);
    border-color: var(--line-soft);
}

body.rp-nav-top .rp-nav-group summary::after,
body.rp-nav-bottom .rp-nav-group summary::after {
    margin-left: 12px;
    transform: rotate(90deg);
}

body.rp-nav-top .rp-nav-group-items,
body.rp-nav-bottom .rp-nav-group-items {
    position: absolute;
    z-index: 80;
    left: 0;
    width: max-content;
    min-width: 220px;
    max-width: 320px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0b1118;
    box-shadow: var(--shadow);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-4px);
    transition: opacity .12s ease, transform .12s ease;
}

body.rp-nav-top .rp-nav-group-items {
    top: calc(100% + 8px);
}

body.rp-nav-bottom .rp-nav-group-items {
    bottom: calc(100% + 8px);
    transform: translateY(4px);
}

body.rp-nav-top .rp-nav-group:hover .rp-nav-group-items,
body.rp-nav-top .rp-nav-group:focus-within .rp-nav-group-items,
body.rp-nav-bottom .rp-nav-group:hover .rp-nav-group-items,
body.rp-nav-bottom .rp-nav-group:focus-within .rp-nav-group-items {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

body.rp-nav-top .rp-nav-group-items .rp-btn,
body.rp-nav-bottom .rp-nav-group-items .rp-btn {
    width: 100%;
    white-space: normal;
}

body.rp-nav-top .rp-user-pill,
body.rp-nav-bottom .rp-user-pill {
    order: 0;
    width: auto;
    margin-top: 0;
    white-space: nowrap;
}

body.rp-nav-top .rp-feature-search,
body.rp-nav-bottom .rp-feature-search {
    width: min(300px, 24vw);
    min-width: 220px;
    margin: 0;
    padding: 8px;
}

body.rp-nav-top .rp-feature-search label,
body.rp-nav-bottom .rp-feature-search label {
    display: none;
}

body.rp-nav-top .rp-feature-search-control,
body.rp-nav-bottom .rp-feature-search-control {
    grid-template-columns: minmax(0, 1fr) auto;
}

body.rp-nav-top .rp-shell,
body.rp-nav-top .container,
body.rp-nav-top .rp-container {
    margin: 0 !important;
    padding-top: 104px !important;
}

body.rp-nav-bottom .rp-shell,
body.rp-nav-bottom .container,
body.rp-nav-bottom .rp-container {
    margin: 0 !important;
    padding-bottom: 116px !important;
}

.rp-btn:hover,
.btn:hover,
button:hover {
    transform: translateY(-1px);
    background: var(--accent-2) !important;
}

.rp-btn.secondary,
.btn-secondary {
    background: var(--surface-2) !important;
    color: var(--ink) !important;
    border-color: var(--line) !important;
    font-weight: 700 !important;
}

.rp-btn.secondary:hover,
.btn-secondary:hover {
    background: var(--surface-3) !important;
    border-color: rgba(47, 191, 131, .42) !important;
    color: var(--ink) !important;
}

.auction-head {
    align-items: stretch;
}

.auction-layout {
    display: grid;
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
    gap: 18px;
}

.auction-create {
    position: sticky;
    top: 18px;
    align-self: start;
}

.auction-form,
.auction-filter {
    display: grid;
    gap: 12px;
}

.auction-form label,
.auction-filter label {
    display: grid;
    gap: 7px;
    color: var(--ink);
    font-weight: 800;
}

.auction-form input,
.auction-form select,
.auction-form textarea,
.auction-filter input,
.auction-filter select {
    width: 100%;
}

.auction-form textarea {
    min-height: 140px;
    resize: vertical;
}

.auction-filter {
    grid-template-columns: minmax(220px, 1fr) minmax(150px, 190px) minmax(170px, 210px) auto auto;
    align-items: end;
    margin-bottom: 16px;
}

.auction-board {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.auction-card {
    display: grid;
    gap: 14px;
    min-width: 0;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background:
        linear-gradient(135deg, rgba(47, 191, 131, .12), transparent 42%),
        var(--surface);
    box-shadow: var(--shadow-soft);
}

.auction-card header,
.auction-card footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.auction-card h2 {
    margin: 0;
    color: var(--ink);
    font-size: 22px;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.auction-card p {
    margin: 0;
    color: var(--muted);
    overflow-wrap: anywhere;
}

.auction-card dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

.auction-card dl div {
    min-width: 0;
    padding: 10px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: rgba(255, 255, 255, .025);
}

.auction-card dt {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.auction-card dd {
    margin: 3px 0 0;
    color: var(--ink);
    font-weight: 800;
    overflow-wrap: anywhere;
}

@media (max-width: 1180px) {
    .auction-layout {
        grid-template-columns: 1fr;
    }

    .auction-create {
        position: static;
    }
}

@media (max-width: 900px) {
    .auction-filter,
    .auction-board,
    .auction-card dl {
        grid-template-columns: 1fr;
    }
}

.rp-btn.disabled,
.rp-btn:disabled,
button:disabled {
    opacity: .55;
    cursor: not-allowed;
    transform: none !important;
}

.rp-inline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
}

.rp-link-button {
    display: inline;
    padding: 0;
    border: 0;
    background: transparent;
    color: #f6c343;
    cursor: pointer;
    font: inherit;
    font-weight: 800;
    text-decoration: none;
}

.rp-link-button:hover,
.rp-link-button:focus-visible {
    color: #ffd977;
    text-decoration: underline;
}

.rp-build-download-wrap.is-floating {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 140;
    width: min(264px, calc(100vw - 28px));
}

.rp-build-download-wrap.is-inline {
    width: min(360px, 100%);
}

.rp-build-download-card,
.rp-build-download-status {
    display: grid;
    min-height: 64px;
    align-content: center;
    gap: 2px;
    padding: 13px 16px 12px;
    border: 1px solid rgba(47, 191, 131, .5);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(47, 191, 131, .22), rgba(246, 195, 67, .12)),
        #101821;
    color: var(--ink);
    text-decoration: none;
    box-shadow:
        0 0 0 4px rgba(47, 191, 131, .08),
        0 16px 40px rgba(0, 0, 0, .38);
    transform: translateZ(0);
    transition: transform .14s ease, border-color .14s ease, box-shadow .14s ease, background .14s ease;
}

.rp-build-download-card:hover,
.rp-build-download-card:focus-visible {
    color: var(--ink);
    border-color: rgba(246, 195, 67, .62);
    background:
        linear-gradient(135deg, rgba(47, 191, 131, .28), rgba(246, 195, 67, .18)),
        #121d27;
    transform: translateY(-2px);
    box-shadow:
        0 0 0 4px rgba(47, 191, 131, .12),
        0 20px 48px rgba(0, 0, 0, .44);
}

.rp-build-download-card span,
.rp-build-download-status span {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.15;
    letter-spacing: 0;
    text-transform: uppercase;
}

.rp-build-download-card strong {
    flex: 0 0 auto;
    padding: 3px 6px;
    border: 1px solid rgba(246, 195, 67, .45);
    border-radius: 999px;
    background: rgba(246, 195, 67, .16);
    color: #f6c343;
    font-size: 10px;
    font-weight: 900;
    line-height: 1;
}

.rp-build-download-card small,
.rp-build-download-status small {
    min-width: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rp-build-download-status {
    border-color: rgba(150, 163, 175, .38);
    background: linear-gradient(135deg, #141c26 0%, #1a2531 100%);
    color: var(--ink);
    box-shadow: 0 14px 38px rgba(0, 0, 0, .34);
}

.rp-build-download-status small {
    color: var(--muted);
}

.rp-build-download-status.is-floating {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 140;
    width: min(264px, calc(100vw - 28px));
}

.rp-build-download-status.is-inline {
    width: min(360px, 100%);
}

body.rp-nav-bottom .rp-build-download-wrap.is-floating,
body.rp-nav-bottom .rp-build-download-status.is-floating {
    bottom: 96px;
}

body.rp-download-modal-open {
    overflow: hidden;
}

.rp-download-modal[hidden] {
    display: none;
}

.rp-download-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 18px;
}

.rp-download-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(3, 8, 13, .72);
    backdrop-filter: blur(8px);
}

.rp-download-modal-panel {
    position: relative;
    z-index: 1;
    display: grid;
    width: min(520px, 100%);
    gap: 16px;
    padding: 24px;
    border: 1px solid rgba(47, 191, 131, .42);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(47, 191, 131, .14), rgba(246, 195, 67, .08)),
        #0b1118;
    box-shadow: 0 28px 90px rgba(0, 0, 0, .55);
}

.rp-download-modal-panel h2 {
    margin: -8px 36px 0 0;
    color: var(--ink);
    font-size: clamp(24px, 4vw, 34px);
    line-height: 1;
}

.rp-download-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    display: grid;
    width: 36px;
    height: 36px;
    place-items: center;
    border: 1px solid rgba(150, 163, 175, .28);
    border-radius: 8px;
    background: rgba(255, 255, 255, .04);
    color: var(--ink);
    cursor: pointer;
    font-size: 28px;
    line-height: 1;
}

.rp-download-modal-close:hover,
.rp-download-modal-close:focus-visible {
    border-color: rgba(246, 195, 67, .6);
    background: rgba(246, 195, 67, .1);
}

.rp-download-modal-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.rp-download-os-card {
    display: grid;
    min-height: 112px;
    align-content: center;
    gap: 8px;
    padding: 18px;
    border: 1px solid rgba(47, 191, 131, .38);
    border-radius: 8px;
    background: rgba(16, 24, 33, .92);
    color: var(--ink);
    text-decoration: none;
    transition: transform .14s ease, border-color .14s ease, background .14s ease;
}

.rp-download-os-card:hover,
.rp-download-os-card:focus-visible {
    border-color: rgba(246, 195, 67, .62);
    background: rgba(21, 33, 43, .96);
    color: var(--ink);
    transform: translateY(-2px);
}

.rp-download-os-card.is-disabled,
.rp-download-os-card.is-disabled:hover,
.rp-download-os-card.is-disabled:focus-visible {
    border-color: rgba(150, 163, 175, .22);
    background: rgba(16, 24, 33, .55);
    color: rgba(229, 239, 235, .48);
    cursor: not-allowed;
    transform: none;
}

.rp-download-os-card span {
    font-size: 18px;
    font-weight: 900;
}

.rp-download-os-card small {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.rp-download-manual-link {
    justify-self: center;
    color: #f6c343;
    font-size: 14px;
    font-weight: 900;
    text-decoration: none;
}

.rp-download-manual-link:hover,
.rp-download-manual-link:focus-visible {
    color: #ffd977;
    text-decoration: underline;
}

@media (max-width: 560px) {
    .rp-download-modal-panel {
        padding: 20px;
    }

    .rp-download-modal-actions {
        grid-template-columns: 1fr;
    }

    .rp-download-os-card {
        min-height: 86px;
    }
}

.notification-popup {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 1000;
    display: grid;
    width: min(420px, calc(100vw - 28px));
    gap: 12px;
    padding: 18px;
    border: 1px solid rgba(47, 191, 131, .42);
    border-radius: 8px;
    background: #0b1118;
    box-shadow: 0 22px 70px rgba(0, 0, 0, .42);
}

.notification-popup h2,
.notification-popup p {
    margin: 0;
}

.notification-popup p {
    color: var(--muted);
    line-height: 1.5;
}

.notification-popup-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.btn-danger {
    background: var(--danger) !important;
    color: #160505 !important;
}

.btn-warning {
    background: var(--warn) !important;
    color: #160f03 !important;
}

a:focus-visible,
button:focus-visible,
.rp-btn:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    outline: 3px solid rgba(47, 191, 131, .25) !important;
    outline-offset: 2px;
}

.rp-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 16px;
    min-height: 460px;
    margin-bottom: 16px;
}

.rp-hero-main {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 460px;
    overflow: hidden;
    padding: clamp(28px, 4vw, 52px);
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(9, 13, 18, .96), rgba(9, 13, 18, .72)),
        url("https://images.unsplash.com/photo-1494526585095-c41746248156?auto=format&fit=crop&w=1800&q=80") center/cover;
    box-shadow: var(--shadow);
}

.rp-eyebrow {
    margin: 0 0 12px;
    color: var(--accent-2);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.rp-hero h1,
.rp-page-head h1 {
    margin: 0;
    color: var(--ink);
    font-size: clamp(30px, 4.2vw, 58px);
    line-height: 1.02;
    letter-spacing: 0;
}

.rp-hero-copy,
.rp-lead {
    max-width: 760px;
    color: var(--muted);
    font-size: 16px;
    line-height: 1.65;
}

.rp-hero-actions,
.rp-action-row,
.rp-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
}

.rp-page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 16px;
    padding: 20px 22px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.rp-page-head > .rp-btn,
.rp-page-head > form,
.rp-section-title > .rp-btn,
.rp-section-title > form {
    flex: 0 0 auto;
}

.rp-command-panel,
.rp-panel,
.card {
    margin-bottom: 16px !important;
    padding: 18px !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    background: var(--surface) !important;
    box-shadow: var(--shadow-soft) !important;
}

.rp-command-panel {
    display: grid;
    grid-template-columns: 1fr;
    align-content: start;
    gap: 8px;
}

.rp-command-panel .rp-btn {
    justify-content: flex-start !important;
    width: 100%;
}

.rp-section-title {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 14px;
    margin: 28px 0 12px;
}

.rp-section-title h2,
.card h2,
.container h2,
.rp-panel h2 {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    color: var(--ink) !important;
    font-size: clamp(22px, 2vw, 32px) !important;
    line-height: 1.1 !important;
}

.rp-section-title p,
.rp-muted {
    margin: 6px 0 0;
    color: var(--muted);
    line-height: 1.55;
}

.rp-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 14px;
}

.rp-news-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 16px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.rp-news-tab {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-height: 38px;
    padding: 8px 12px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: rgba(255, 255, 255, .025);
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}

.rp-news-tab:hover,
.rp-news-tab.active {
    border-color: rgba(47, 191, 131, .42);
    background: rgba(47, 191, 131, .10);
    color: var(--ink);
}

.rp-news-tab strong {
    min-width: 24px;
    padding: 3px 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    color: var(--accent-2);
    font-size: 11px;
    line-height: 1.2;
    text-align: center;
}

.rp-col-3 { grid-column: span 3; }
.rp-col-4 { grid-column: span 4; }
.rp-col-5 { grid-column: span 5; }
.rp-col-6 { grid-column: span 6; }
.rp-col-7 { grid-column: span 7; }
.rp-col-8 { grid-column: span 8; }
.rp-col-12 { grid-column: span 12; }

.rp-card,
.mod-item,
.stat-box,
.table-item,
.info-box,
.download-section {
    padding: 16px !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    background: linear-gradient(180deg, rgba(255,255,255,.018), transparent 70%), var(--surface) !important;
    box-shadow: none !important;
    transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

.rp-card:hover,
.rp-service-link:hover {
    border-color: rgba(47, 191, 131, .34) !important;
    background: var(--surface-2) !important;
}

.rp-card.compact {
    padding: 14px !important;
}

.rp-card h3,
.rp-card h4 {
    margin: 0 0 8px;
    color: var(--ink);
}

.rp-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.58;
}

.rp-service-link {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 100%;
    gap: 16px;
    text-decoration: none;
}

.rp-kpi {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.rp-kpi p {
    margin: 0 0 6px;
}

.rp-kpi strong {
    display: block;
    font-size: 30px;
    line-height: 1;
}

.rp-kpi span,
.rp-chip,
.badge {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 4px 9px;
    border: 1px solid rgba(47, 191, 131, .28);
    border-radius: 999px !important;
    background: rgba(47, 191, 131, .12) !important;
    color: var(--accent-2) !important;
    font-size: 12px;
    font-weight: 800;
}

.rp-chip.warn {
    border-color: rgba(215, 168, 73, .38);
    background: rgba(215, 168, 73, .12) !important;
    color: #f0c978 !important;
}

.rp-chip.status-approved {
    border-color: rgba(47, 191, 131, .42);
    background: rgba(47, 191, 131, .14) !important;
    color: #83e6ba !important;
}

.rp-chip.status-rejected {
    border-color: rgba(224, 107, 107, .45);
    background: rgba(224, 107, 107, .14) !important;
    color: #ffa6a6 !important;
}

.rp-chip.status-revision {
    border-color: rgba(215, 168, 73, .45);
    background: rgba(215, 168, 73, .14) !important;
    color: #f2cf81 !important;
}

.rp-chip.status-review {
    border-color: rgba(106, 169, 255, .45);
    background: rgba(106, 169, 255, .13) !important;
    color: #abd0ff !important;
}

.rp-chip.status-neutral {
    border-color: rgba(150, 163, 175, .32);
    background: rgba(150, 163, 175, .1) !important;
    color: #c7d0d8 !important;
}

.rp-bank-balance,
.rp-account-balance {
    display: grid;
    gap: 3px;
    min-width: min(100%, 300px);
    padding: 16px 18px;
    border: 1px solid rgba(47, 191, 131, .28);
    border-radius: 8px;
    background: rgba(47, 191, 131, .09);
}

.rp-bank-balance span,
.rp-account-balance span {
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.rp-bank-balance strong {
    color: var(--ink);
    font-size: clamp(30px, 4vw, 46px);
    font-weight: 900;
    line-height: 1;
}

.rp-bank-balance small,
.rp-account-balance small {
    color: var(--muted);
    font-size: 13px;
}

.rp-account-balance {
    margin: 12px 0 16px;
}

.rp-account-balance strong {
    color: var(--ink);
    font-size: 28px;
    font-weight: 900;
    line-height: 1.1;
}

.rp-list {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.rp-list li {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 11px 0;
    border-bottom: 1px solid var(--line);
    color: var(--muted);
}

.rp-list li:last-child {
    border-bottom: 0;
}

.rp-list strong {
    color: var(--ink);
}

.rp-list span {
    min-width: 0;
    text-align: right;
    overflow-wrap: anywhere;
}

.rp-list.compact li {
    padding: 7px 0;
    font-size: 12px;
}

.rp-list.compact strong {
    color: #cfd8e3;
    font-weight: 800;
}

.rp-progress {
    width: 100%;
    height: 8px;
    overflow: hidden;
    border-radius: 999px;
    background: var(--surface-3);
}

.rp-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--accent);
}

.rp-doc {
    color: var(--ink);
    background: #102018 !important;
    border-color: rgba(47, 191, 131, .32) !important;
}

.rp-doc p,
.rp-doc .rp-muted {
    color: #a9bbb4;
}

.rp-media {
    min-height: 240px;
    display: flex;
    align-items: end;
    color: #fff;
    background-size: cover !important;
    background-position: center !important;
}

.rp-media div {
    width: 100%;
}

.rp-table-wrap {
    width: 100%;
    overflow-x: auto;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0d131a;
}

table {
    width: 100% !important;
    overflow: hidden;
    border: 0;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    border-radius: 0;
    background: transparent;
}

table thead {
    background: #151f2a !important;
    color: var(--ink) !important;
}

table th,
table td {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--line) !important;
    color: var(--ink);
    text-align: left;
    vertical-align: top;
}

table th {
    color: #b9c6d0;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
}

table tbody tr:hover {
    background: rgba(47, 191, 131, .055) !important;
}

table tbody tr:last-child td,
table tbody tr:last-child th {
    border-bottom: 0 !important;
}

table table {
    border: 1px solid var(--line-soft);
    background: rgba(255, 255, 255, .015);
}

table table th,
table table td {
    padding: 7px 8px !important;
    font-size: 12px;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.rp-checkbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px 14px;
    padding: 10px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.03);
}

.rp-checkbox-grid label {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    color: var(--text);
}

.form-group {
    margin-bottom: 14px;
}

.form-group.full {
    grid-column: 1 / -1;
}

label {
    display: block;
    margin-bottom: 6px;
    color: #c9d3dc;
    font-size: 12px;
    font-weight: 800;
}

input,
textarea,
select {
    width: 100%;
    min-height: 40px;
    padding: 9px 11px !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    background: #0b1118 !important;
    color: var(--ink) !important;
    font: inherit !important;
}

input[readonly] {
    border-color: rgba(90, 111, 132, .7) !important;
    background:
        linear-gradient(90deg, rgba(47, 191, 131, .24) 0 4px, rgba(18, 27, 36, .96) 4px 100%) !important;
    color: #d7e0e7 !important;
    cursor: default;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .03);
}

input[readonly]:focus {
    border-color: rgba(90, 111, 132, .85) !important;
    outline: 3px solid rgba(90, 111, 132, .2) !important;
}

textarea {
    min-height: 104px;
    resize: vertical;
}

form.rp-inline-form,
.rp-inline-form {
    display: contents;
}

.rp-compact-form {
    display: grid;
    gap: 8px;
    min-width: 240px;
}

.rp-compact-form .form-group {
    margin-bottom: 0;
}

.rp-compact-form textarea {
    min-height: 74px;
}

.rp-compact-form input,
.rp-compact-form select,
.rp-compact-form textarea {
    min-height: 34px;
    padding: 7px 9px !important;
    font-size: 12px !important;
}

input:focus,
textarea:focus,
select:focus {
    border-color: rgba(47, 191, 131, .58) !important;
    outline: 3px solid rgba(47, 191, 131, .18) !important;
}

option {
    background: var(--surface);
    color: var(--ink);
}

details:not(.rp-nav-group) {
    padding: 9px 11px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0d131a;
}

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

.bank-choice-card,
.bank-hero,
.bank-balance-panel,
.bank-feature-grid article,
.bank-cashback-list article,
.bank-mini-stat {
    border: 1px solid var(--line);
    border-radius: 8px;
}

.bank-choice-card {
    display: grid;
    gap: 16px;
    min-height: 420px;
    padding: 22px;
    background: #0d131a;
    box-shadow: var(--shadow);
}

.bank-choice-card h2,
.bank-hero h1 {
    margin: 0 0 10px;
}

.bank-cashback-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bank-cashback-strip span {
    padding: 7px 9px;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 999px;
    color: #dfe8ee;
    font-size: 12px;
    font-weight: 800;
}

.bank-default-services {
    display: grid;
    gap: 16px;
}

.bank-service-strip,
.bank-rule-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.bank-service-strip article,
.bank-rule-grid article,
.bank-card-note {
    display: grid;
    gap: 6px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(255, 255, 255, .035);
}

.bank-service-strip strong,
.bank-rule-grid strong,
.bank-card-note strong {
    color: #f4f7fb;
}

.bank-service-strip span,
.bank-rule-grid small,
.bank-card-note span {
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.bank-rule-grid span {
    color: var(--accent);
    font-weight: 900;
}

.bank-page {
    display: grid;
    gap: 16px;
}

.bank-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 18px;
    align-items: stretch;
    min-height: 320px;
    padding: 28px;
    overflow: hidden;
}

.bank-balance-panel {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 220px;
    padding: 20px;
    background: rgba(5, 10, 16, .55);
}

.bank-balance-panel span,
.bank-mini-stat span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.bank-balance-panel strong {
    display: block;
    margin: 8px 0;
    font-size: clamp(26px, 4vw, 44px);
    line-height: 1;
}

.bank-balance-panel small {
    color: var(--muted);
}

.bank-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.bank-feature-grid article {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 14px;
    background: #0d131a;
}

.bank-feature-grid article span {
    width: 8px;
    height: 32px;
    border-radius: 999px;
    flex: 0 0 auto;
}

.bank-feature-grid p {
    margin: 0;
    color: #d5dee5;
    font-size: 13px;
}

.bank-cashback-list {
    display: grid;
    gap: 10px;
}

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

.bank-card-tier {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0b1118;
}

.bank-card-tier h3 {
    margin: 0;
}

.bank-card-tier p {
    margin: 0;
    color: var(--muted);
    min-height: 54px;
}

.bank-card-dialog {
    width: min(720px, calc(100vw - 28px));
    max-height: calc(100vh - 40px);
    padding: 18px;
    color: var(--ink);
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0b1118;
}

.bank-card-dialog::backdrop {
    background: rgba(0, 0, 0, .72);
}

.bank-card-dialog form {
    display: grid;
    gap: 14px;
}

.bank-card-choice-list {
    display: grid;
    gap: 10px;
}

.bank-card-choice {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 12px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: rgba(255, 255, 255, .04);
    cursor: pointer;
}

.bank-card-choice input {
    margin-top: 3px;
}

.bank-card-choice strong,
.bank-card-choice small {
    display: block;
}

.bank-card-choice small {
    margin-top: 4px;
    color: var(--muted);
}

.bank-cashback-list article {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 4px 12px;
    align-items: center;
    padding: 12px;
    background: #0b1118;
}

.bank-cashback-list strong {
    grid-row: span 2;
    font-size: 24px;
}

.bank-cashback-list span {
    font-weight: 900;
}

.bank-cashback-list small {
    color: var(--muted);
}

.bank-mini-stat {
    margin-top: 12px;
    padding: 14px;
    background: rgba(255, 255, 255, .04);
}

.bank-mini-stat strong {
    display: block;
    margin-top: 6px;
    font-size: 22px;
}

.bank-theme-citadel.bank-choice-card,
.bank-theme-citadel .bank-hero {
    background:
        linear-gradient(135deg, rgba(13, 39, 44, .96), rgba(10, 16, 24, .98) 58%),
        linear-gradient(90deg, rgba(47, 191, 131, .18), transparent);
    border-color: rgba(47, 191, 131, .32);
}

.bank-theme-citadel .bank-feature-grid article span,
.bank-theme-citadel .bank-cashback-list strong {
    color: #67d8a6;
    background: #67d8a6;
}

.bank-theme-citadel .bank-cashback-list strong {
    background: transparent;
}

.bank-theme-alphach.bank-choice-card,
.bank-theme-alphach .bank-hero {
    background:
        radial-gradient(circle at 86% 18%, rgba(238, 190, 67, .18), transparent 28%),
        linear-gradient(135deg, rgba(43, 25, 12, .96), rgba(13, 13, 18, .98) 58%);
    border-color: rgba(238, 190, 67, .34);
}

.bank-theme-alphach .bank-feature-grid article span,
.bank-theme-alphach .bank-cashback-list strong {
    color: #eebe43;
    background: #eebe43;
}

.bank-theme-alphach .bank-cashback-list strong {
    background: transparent;
}

@media (max-width: 900px) {
    .bank-choice-grid,
    .bank-service-strip,
    .bank-rule-grid,
    .bank-hero,
    .bank-feature-grid,
    .bank-card-grid {
        grid-template-columns: 1fr;
    }
}

summary:not(.rp-nav-group summary) {
    cursor: pointer;
    color: var(--ink);
    font-weight: 800;
}

form[style*="display: grid"],
form[style*="display:grid"] {
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #0d131a;
}

.rp-application-summary {
    min-width: 260px;
    margin-bottom: 10px;
    padding: 12px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: rgba(255, 255, 255, .018);
}

.rp-application-summary > strong {
    display: block;
    margin-bottom: 6px;
    color: var(--ink);
    font-size: 12px;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.rp-application-summary details {
    margin-top: 8px;
    background: rgba(0, 0, 0, .12);
}

.rp-quick-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-bottom: 10px;
}

.rp-quick-actions .rp-btn {
    width: 100%;
    min-height: 32px;
    padding: 7px 8px !important;
    font-size: 12px !important;
}

.rp-admin-player-link {
    margin-top: 8px;
    width: 100%;
}

.rp-admin-player-link.rp-btn {
    justify-content: center !important;
    min-height: 32px;
    padding: 7px 10px !important;
    font-size: 12px !important;
}

.rp-bulk-bar {
    align-items: end;
    margin-bottom: 16px;
    padding: 14px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: rgba(255, 255, 255, .018);
}

.login-page {
    min-height: 100vh !important;
    display: grid !important;
    place-items: center !important;
    padding: 24px !important;
}

.login-container {
    width: min(460px, 100%) !important;
    max-width: 460px !important;
    padding: 30px !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    background: var(--surface) !important;
    box-shadow: var(--shadow) !important;
}

.login-container h1 {
    color: var(--ink) !important;
    font-size: 28px !important;
    line-height: 1.05 !important;
    text-align: left !important;
}

.error-message,
.message.error {
    margin-bottom: 16px;
    padding: 12px 14px;
    border-left: 4px solid var(--danger) !important;
    border-radius: 8px;
    background: rgba(224, 107, 107, .12) !important;
    color: #ffb2b2 !important;
}

.info-message,
.message.success,
.tip {
    margin-bottom: 16px;
    padding: 12px 14px;
    border-left: 4px solid var(--accent) !important;
    border-radius: 8px;
    background: rgba(47, 191, 131, .12) !important;
    color: #a8eccd !important;
}

@media (max-width: 1180px) {
    :root {
        --sidebar: 248px;
    }

    .rp-hero {
        grid-template-columns: 1fr;
    }

    .rp-col-3,
    .rp-col-4,
    .rp-col-5,
    .rp-col-6,
    .rp-col-7,
    .rp-col-8 {
        grid-column: span 6;
    }
}

@media (max-width: 860px) {
    .navbar,
    .rp-topbar {
        position: sticky;
        top: 0;
        width: 100% !important;
        height: auto;
        flex-direction: column;
        margin: 0 !important;
        padding: 12px !important;
        border-right: 0 !important;
        border-bottom: 1px solid var(--line) !important;
    }

    .rp-brand,
    .navbar h1 {
        width: 100%;
        padding-bottom: 10px;
    }

    .rp-nav,
    .navbar-right {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: 42vh;
        overflow-y: auto;
    }

    .rp-nav .rp-btn,
    .navbar-right a,
    .rp-user-pill {
        width: 100%;
        min-width: 0;
        white-space: normal;
    }

    .rp-nav-group {
        grid-column: span 2;
    }

    .rp-shell,
    .container,
    .rp-container {
        margin: 0 !important;
        padding: 16px 14px 42px !important;
    }

    .rp-page-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .rp-page-head > .rp-btn,
    .rp-page-head > form,
    .rp-page-head > form .rp-btn {
        width: 100%;
    }

    .rp-build-download-wrap.is-floating,
    .rp-build-download-status.is-floating {
        left: 14px;
        bottom: 14px;
        width: min(248px, calc(100vw - 28px));
    }

    .rp-build-download-card,
    .rp-build-download-status {
        min-height: 58px;
        padding: 11px 14px;
    }

    body.rp-nav-bottom .rp-build-download-wrap.is-floating,
    body.rp-nav-bottom .rp-build-download-status.is-floating {
        bottom: 14px;
    }
}

@media (max-width: 720px) {
    .rp-hero-main {
        min-height: 380px;
        padding: 22px;
    }

    .rp-col-3,
    .rp-col-4,
    .rp-col-5,
    .rp-col-6,
    .rp-col-7,
    .rp-col-8,
    .rp-col-12 {
        grid-column: span 12;
    }

    .rp-section-title {
        align-items: flex-start;
        flex-direction: column;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .rp-list li {
        align-items: flex-start;
        flex-direction: column;
        gap: 4px;
    }

    table th,
    table td {
        padding: 10px !important;
    }
}

/* Standalone bank applications */
.citadel-app,
.alphach-app {
    margin: 0;
    min-height: 100vh;
    overflow-x: hidden;
}

.bank-notify-anchor {
    position: fixed;
    right: 18px;
    top: 14px;
    z-index: 50;
    padding: 9px 12px;
    border-radius: 999px;
    background: rgba(0, 0, 0, .55);
    color: #fff !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none !important;
    backdrop-filter: blur(12px);
}

.citadel-app {
    background: #e7ece8;
    color: #18241d;
    font-family: Georgia, "Times New Roman", serif;
}

.citadel-app input,
.citadel-app select,
.citadel-app textarea {
    border: 1px solid #9eaa9f !important;
    border-radius: 2px !important;
    background: #fbfbf5 !important;
    color: #18241d !important;
    font-family: Georgia, "Times New Roman", serif !important;
}

.cb-shell {
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    min-height: 100vh;
}

.cb-rail {
    position: sticky;
    top: 0;
    display: flex;
    flex-direction: column;
    gap: 30px;
    height: 100vh;
    padding: 28px 22px;
    background: #17271f;
    color: #edf4e7;
}

.cb-seal {
    display: grid;
    width: 64px;
    height: 64px;
    place-items: center;
    border: 2px solid #d8c27a;
    border-radius: 50%;
    color: #d8c27a !important;
    font-size: 24px;
    font-weight: 900;
    text-decoration: none !important;
}

.cb-rail nav {
    display: grid;
    gap: 9px;
}

.cb-rail nav a,
.cb-rail-note {
    color: #cfdccd !important;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none !important;
}

.cb-rail nav a {
    padding: 10px 0;
    border-bottom: 1px solid rgba(216, 194, 122, .22);
}

.cb-rail-note {
    margin-top: auto;
    color: #d8c27a !important;
}

.cb-workspace {
    display: grid;
    gap: 22px;
    padding: 34px;
}

.cb-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 22px;
    min-height: 300px;
    padding: 34px;
    border: 1px solid #9eaa9f;
    border-radius: 18px;
    box-shadow: 0 24px 70px rgba(23, 39, 31, .12);
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .55), rgba(255, 255, 255, .18)),
        repeating-linear-gradient(135deg, rgba(23, 39, 31, .045) 0 2px, transparent 2px 10px),
        #f4f1e3;
}

.cb-hero p,
.cb-paper-head span,
.cb-section-head span,
.cb-balance-book small,
.cb-register-grid span,
.cb-service-panel h2 + div,
.cb-dialog-head span {
    text-transform: uppercase;
    letter-spacing: .08em;
}

.cb-hero h1 {
    max-width: 620px;
    margin: 16px 0;
    color: #17271f;
    font-size: clamp(46px, 7vw, 94px);
    line-height: .9;
}

.cb-hero span {
    display: block;
    max-width: 640px;
    color: #506259;
    font-size: 19px;
    line-height: 1.5;
}

.cb-balance-book {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
    border: 1px solid #17271f;
    border-radius: 16px;
    background: #17271f;
    color: #edf4e7;
}

.cb-balance-book strong {
    margin: 10px 0;
    color: #d8c27a;
    font-size: clamp(34px, 5vw, 62px);
    line-height: .9;
}

.cb-balance-book em {
    font-style: normal;
    color: #cfdccd;
}

.cb-alert {
    padding: 13px 16px;
    border-left: 5px solid #d8c27a;
    background: #fffaf0;
    color: #18241d;
    font-weight: 700;
}

.cb-alert.error {
    border-color: #9b2c2c;
}

.cb-register-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.cb-currency-strip,
.ab-currency-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 16px 0;
}

.cb-currency-strip span {
    padding: 13px;
    border: 1px solid #d9d4bd;
    background: #f7f5eb;
    color: #17271f;
    font-weight: 900;
}

.ab-currency-strip span {
    padding: 13px;
    border-radius: 18px;
    background: rgba(255, 255, 255, .08);
    color: #f6f7fb;
    font-weight: 900;
}

.cb-register-grid article,
.cb-paper,
.cb-service-panel,
.cb-card-vault,
.cb-history,
.cb-danger-zone {
    border: 1px solid #9eaa9f;
    background: #f7f5eb;
}

.cb-register-grid article {
    display: grid;
    gap: 8px;
    padding: 18px;
}

.cb-register-grid strong {
    color: #17271f;
    font-size: 28px;
}

.cb-register-grid small,
.cb-service-panel small,
.cb-card-grid p,
.cb-table small,
.cb-danger-zone p {
    color: #5d6b62;
}

.cb-ledger-layout,
.cb-document-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
    align-items: start;
}

.cb-stack {
    display: grid;
    gap: 18px;
}

.cb-paper,
.cb-service-panel,
.cb-card-vault,
.cb-history,
.cb-danger-zone {
    padding: 22px;
}

.cb-paper-head,
.cb-section-head,
.cb-dialog-head {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 18px;
}

.cb-paper h2,
.cb-service-panel h2,
.cb-card-vault h2,
.cb-history h2,
.cb-danger-zone h2,
.cb-dialog h2 {
    margin: 0;
    color: #17271f;
    font-size: 28px;
}

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

.cb-form-grid label,
.cb-danger-zone label {
    display: grid;
    gap: 6px;
    color: #44534a;
    font-size: 13px;
    font-weight: 800;
}

.cb-form-grid .wide {
    grid-column: 1 / -1;
}

.cb-primary,
.cb-secondary,
.cb-danger-zone button,
.cb-dialog button {
    min-height: 40px;
    margin-top: 14px;
    border: 1px solid #17271f !important;
    border-radius: 2px !important;
    background: #17271f !important;
    color: #f7f5eb !important;
    font-family: Georgia, "Times New Roman", serif !important;
}

.cb-secondary,
.cb-dialog button[type="button"] {
    background: #f7f5eb !important;
    color: #17271f !important;
}

.cb-right-column {
    display: grid;
    gap: 18px;
}

.cb-service-list {
    display: grid;
    gap: 8px;
}

.cb-service-list span {
    padding: 10px;
    border-left: 4px solid #d8c27a;
    background: #eeebdc;
    font-weight: 800;
}

.cb-mini-service {
    display: grid;
    gap: 8px;
    padding: 12px;
    border-left: 4px solid #d8c27a;
    background: #eeebdc;
}

.cb-mini-service strong,
.cb-mini-service span,
.cb-mini-service small,
.cb-cashback-rule strong,
.cb-cashback-rule span,
.cb-cashback-rule small {
    display: block;
}

.cb-mini-service small,
.cb-cashback-rule small,
.cb-auto-note {
    color: #5f665f;
    font-size: 13px;
}

.cb-mini-service input,
.cb-mini-service button {
    min-height: 38px;
}

.cb-mini-service > span {
    color: #1f5c3b;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.cb-cashback-rule {
    display: grid;
    gap: 3px;
    padding: 12px 0;
    border-bottom: 1px solid #d9d4bd;
}

.cb-cashback-rule span {
    color: #1f5c3b;
    font-weight: 900;
}

.cb-system-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

.cb-system-link {
    padding: 11px;
    border: 1px solid #d9d4bd;
    background: #f7f5eb;
    color: #17271f;
    text-decoration: none;
    font-weight: 800;
}

.cb-rail-note .cb-system-link {
    display: block;
    margin-top: 8px;
    padding: 8px;
    font-size: 12px;
}

.cb-cashback-row {
    display: grid;
    grid-template-columns: 70px minmax(0, 1fr);
    gap: 4px 10px;
    padding: 12px 0;
    border-bottom: 1px solid #d9d4bd;
}

.cb-cashback-row strong {
    grid-row: span 2;
    color: #1f5c3b;
    font-size: 25px;
}

.cb-debt-list,
.ab-debt-list {
    display: grid;
    gap: 10px;
}

.cb-debt-row,
.ab-debt-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid rgba(184, 219, 204, .14);
    border-radius: 16px;
    background: rgba(255, 255, 255, .045);
}

.cb-debt-row strong,
.cb-debt-row span,
.cb-debt-row small,
.ab-debt-row strong,
.ab-debt-row span,
.ab-debt-row small {
    display: block;
}

.cb-debt-row b,
.ab-debt-row b {
    color: #42b883;
    white-space: nowrap;
}

.cb-debt-filters,
.ab-debt-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 12px;
}

.cb-debt-filters button,
.ab-debt-filters button,
.cb-autopay-form button,
.ab-autopay-form button {
    min-height: 36px;
    padding: 8px 12px;
}

.cb-debt-filters button.active,
.ab-debt-filters button.active {
    border-color: #42b883 !important;
    background: #0f3a28 !important;
    color: #e7fff2 !important;
}

.cb-autopay-form,
.ab-autopay-form {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-bottom: 12px;
}

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

.cb-card-grid article {
    display: grid;
    min-height: 220px;
    padding: 18px;
    border: 1px solid #17271f;
    background: linear-gradient(135deg, #17271f, #33473a);
    color: #f7f5eb;
}

.cb-card-grid h3 {
    margin: 10px 0;
    color: #d8c27a;
    font-size: 30px;
}

.cb-card-grid strong {
    align-self: end;
}

.cb-danger-zone {
    display: grid;
    gap: 12px;
    border-color: #9b2c2c;
    background: #fff2ed;
}

.cb-table {
    overflow-x: auto;
}

.cb-table table {
    width: 100%;
    border-collapse: collapse;
    color: #18241d;
}

.cb-table th,
.cb-table td {
    padding: 13px;
    border-bottom: 1px solid #d9d4bd;
    text-align: left;
}

.cb-table th {
    background: #eeebdc;
    color: #44534a;
}

.cb-table td span {
    display: inline-block;
    padding: 5px 8px;
    border: 1px solid #9eaa9f;
    background: #fbfbf5;
}

.cb-empty {
    color: #5d6b62;
}

.cb-dialog {
    width: min(720px, calc(100vw - 28px));
    padding: 24px;
    border: 1px solid #17271f;
    background: #f7f5eb;
    color: #18241d;
}

.cb-dialog::backdrop {
    background: rgba(23, 39, 31, .72);
}

.cb-card-options {
    display: grid;
    gap: 10px;
}

.cb-card-options label {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 8px;
    padding: 12px;
    border: 1px solid #9eaa9f;
    background: #fbfbf5;
}

.cb-card-options strong,
.cb-card-options small {
    display: block;
}

.alphach-app {
    background:
        radial-gradient(circle at 12% 12%, rgba(255, 58, 97, .22), transparent 30%),
        radial-gradient(circle at 82% 0%, rgba(255, 214, 71, .28), transparent 28%),
        #08070a;
    color: #fff;
    font-family: Inter, Arial, sans-serif;
}

.alphach-app input,
.alphach-app select,
.alphach-app textarea {
    border: 1px solid rgba(255, 255, 255, .16) !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, .08) !important;
    color: #fff !important;
}

.alphach-app option {
    background: #151116;
}

.ab-app {
    width: min(1440px, calc(100vw - 36px));
    margin: 0 auto;
    padding: 26px 0 48px;
}

.ab-top {
    display: grid;
    grid-template-columns: 70px minmax(0, 1fr) auto;
    gap: 16px;
    align-items: center;
    margin-bottom: 20px;
}

.ab-logo {
    display: grid;
    width: 56px;
    height: 56px;
    place-items: center;
    border-radius: 18px;
    background: #ff365f;
    color: #fff !important;
    font-size: 26px;
    font-weight: 1000;
    text-decoration: none !important;
}

.ab-top nav {
    display: flex;
    gap: 8px;
    justify-content: center;
    padding: 8px;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    backdrop-filter: blur(18px);
}

.ab-top nav button,
.ab-top > a {
    min-height: 42px;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    color: rgba(255, 255, 255, .72) !important;
    font-weight: 900 !important;
}

.ab-top nav button.active {
    background: #fff !important;
    color: #08070a !important;
}

.ab-top > a {
    padding: 11px 16px;
    text-decoration: none !important;
}

.ab-alert {
    margin-bottom: 14px;
    padding: 14px 16px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 18px;
    background: rgba(255, 255, 255, .08);
}

.ab-alert.error {
    border-color: rgba(255, 54, 95, .56);
}

.ab-panel[hidden] {
    display: none;
}

.ab-dashboard {
    display: grid;
    grid-template-columns: 380px minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
}

.ab-phone {
    display: grid;
    min-height: 640px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 42px;
    background:
        linear-gradient(160deg, rgba(255, 54, 95, .38), rgba(255, 214, 71, .20) 42%, rgba(255, 255, 255, .08)),
        #121015;
    box-shadow: 0 30px 90px rgba(0, 0, 0, .42), inset 0 0 0 1px rgba(255, 255, 255, .08);
}

.ab-metrics article,
.ab-glass-form,
.ab-transfer,
.ab-ai-card,
.ab-products,
.ab-card-store,
.ab-rewards,
.ab-feed,
.ab-side-forms form {
    border-radius: 28px;
    box-shadow: 0 20px 70px rgba(0, 0, 0, .2);
}

.ab-phone-top {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: rgba(255, 255, 255, .78);
    font-size: 12px;
    font-weight: 900;
}

.ab-balance {
    align-self: center;
}

.ab-balance small,
.ab-metrics span,
.ab-ai-card span,
.ab-card-store span,
.ab-dialog-head span {
    display: block;
    color: rgba(255, 255, 255, .62);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.ab-balance strong {
    display: block;
    margin: 8px 0;
    font-size: clamp(44px, 8vw, 88px);
    line-height: .88;
}

.ab-fast-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    align-self: end;
}

.ab-fast-actions button,
.ab-glass-form button,
.ab-transfer button,
.ab-products button,
.ab-card-store button,
.ab-side-forms button,
.ab-dialog button {
    min-height: 44px;
    border: 0 !important;
    border-radius: 999px !important;
    background: #ff365f !important;
    color: #fff !important;
    font-family: Inter, Arial, sans-serif !important;
    font-weight: 1000 !important;
}

.ab-fast-actions button:nth-child(2),
.ab-products button {
    background: #ffd647 !important;
    color: #151116 !important;
}

.ab-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ab-metrics article,
.ab-glass-form,
.ab-transfer,
.ab-ai-card,
.ab-products,
.ab-card-store,
.ab-rewards,
.ab-feed,
.ab-side-forms form {
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 28px;
    background: rgba(255, 255, 255, .07);
    box-shadow: inset 0 1px rgba(255, 255, 255, .08);
    backdrop-filter: blur(18px);
}

.ab-metrics article {
    display: grid;
    gap: 8px;
    padding: 22px;
}

.ab-metrics strong {
    font-size: 44px;
    line-height: .95;
}

.ab-metrics small,
.ab-feed small,
.ab-card-store small,
.ab-rewards small {
    color: rgba(255, 255, 255, .58);
}

.ab-glass-form {
    grid-column: 2;
    padding: 24px;
}

.ab-glass-form h2,
.ab-transfer h1,
.ab-products h1,
.ab-feed h1,
.ab-ai-card h2,
.ab-card-store h2,
.ab-side-forms h2,
.ab-dialog h2 {
    margin: 0 0 18px;
    color: #fff;
    font-size: clamp(28px, 4vw, 54px);
    line-height: .95;
}

.ab-fields,
.ab-transfer {
    display: grid;
    gap: 12px;
}

.ab-fields {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ab-fields label,
.ab-transfer label,
.ab-side-forms label {
    display: grid;
    gap: 7px;
    color: rgba(255, 255, 255, .72);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.ab-fields .wide,
.ab-transfer .wide {
    grid-column: 1 / -1;
}

.ab-pay-grid,
.ab-feed-layout,
.ab-systems-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
}

.ab-transfer,
.ab-ai-card,
.ab-products,
.ab-card-store,
.ab-rewards,
.ab-feed,
.ab-side-forms form {
    padding: 24px;
}

.ab-transfer {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ab-transfer h1,
.ab-transfer .ab-alert {
    grid-column: 1 / -1;
}

.ab-ai-card ul {
    display: grid;
    gap: 12px;
    margin: 0;
    padding-left: 18px;
    color: rgba(255, 255, 255, .76);
}

.ab-market {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 370px;
    gap: 18px;
}

.ab-products {
    grid-row: span 2;
}

.ab-card-store,
.ab-rewards {
    display: grid;
    gap: 12px;
}

.ab-card-store article,
.ab-rewards div {
    display: grid;
    gap: 4px;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .08);
}

.ab-card-store strong,
.ab-rewards strong {
    color: #ffd647;
    font-size: 24px;
}

.ab-service-list {
    display: grid;
    gap: 12px;
}

.business-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.business-owner-panel {
    display: grid;
    gap: 18px;
}

.business-owner-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.business-simple-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
}

.business-owner-grid form {
    display: grid;
    gap: 12px;
}

.business-control-card {
    min-height: 100%;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
}

.business-control-card label,
.rp-compact-form label {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.business-control-card label > span,
.rp-compact-form label > span {
    color: var(--ink);
}

.business-control-card input,
.business-control-card select,
.business-control-card textarea {
    width: 100%;
}

.business-control-card textarea {
    min-height: 88px;
}

.business-control-card h3 {
    margin: 0;
}

.business-owner-panel > .rp-grid {
    margin: 14px 0;
}

.business-owner-panel > .rp-card {
    margin-top: 12px;
}

.business-owner-panel .rp-table-wrap {
    margin-top: 10px;
}

@media (max-width: 1180px) {
    .business-simple-grid {
        grid-template-columns: 1fr;
    }
}

.ab-mini-service,
.ab-cashback-rule {
    display: grid;
    gap: 8px;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .08);
}

.ab-mini-service strong,
.ab-mini-service span,
.ab-mini-service small,
.ab-cashback-rule strong,
.ab-cashback-rule span,
.ab-cashback-rule small {
    display: block;
}

.ab-mini-service small,
.ab-cashback-rule small,
.ab-auto-note {
    color: rgba(255, 255, 255, .68);
    font-size: 13px;
}

.ab-cashback-rule span {
    color: #ffd647;
    font-weight: 900;
}

.ab-mini-service > span {
    color: #ffd647;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

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

.ab-system-link {
    padding: 12px;
    border-radius: 18px;
    background: rgba(255, 255, 255, .08);
    color: #f6f7fb;
    text-decoration: none;
    font-weight: 900;
}

.ab-feed {
    display: grid;
    gap: 12px;
}

.ab-feed article {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 150px 120px;
    gap: 12px;
    align-items: center;
    padding: 16px;
    border-radius: 22px;
    background: rgba(255, 255, 255, .075);
}

.ab-feed article strong,
.ab-feed article span,
.ab-feed article p,
.ab-feed article b,
.ab-feed article em {
    display: block;
    margin: 0;
}

.ab-feed article b {
    color: #ffd647;
    font-size: 24px;
}

.ab-feed article em {
    justify-self: end;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    font-style: normal;
    font-size: 12px;
    font-weight: 900;
}

.ab-side-forms {
    display: grid;
    gap: 18px;
}

.ab-side-forms form {
    display: grid;
    gap: 12px;
}

.ab-empty {
    color: rgba(255, 255, 255, .58);
}

.ab-dialog {
    width: min(760px, calc(100vw - 28px));
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 30px;
    background: #151116;
    color: #fff;
}

.ab-dialog::backdrop {
    background: rgba(0, 0, 0, .76);
}

.ab-dialog-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.ab-card-options {
    display: grid;
    gap: 10px;
}

.ab-card-options label {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 10px;
    padding: 14px;
    border-radius: 22px;
    background: rgba(255, 255, 255, .08);
}

.ab-card-options strong,
.ab-card-options small {
    display: block;
}

@media (max-width: 980px) {
    .cb-shell,
    .cb-hero,
    .cb-ledger-layout,
    .cb-document-grid,
    .ab-dashboard,
    .ab-pay-grid,
    .ab-market,
    .ab-feed-layout,
    .ab-systems-layout {
        grid-template-columns: 1fr;
    }

    .cb-rail {
        position: static;
        height: auto;
    }

    .cb-register-grid,
    .cb-card-grid,
    .cb-system-grid,
    .cb-currency-strip,
    .ab-metrics,
    .ab-fields,
    .ab-transfer,
    .ab-system-grid,
    .ab-currency-strip,
    .business-owner-grid,
    .cb-debt-row,
    .ab-debt-row {
        grid-template-columns: 1fr;
    }

    .ab-glass-form {
        grid-column: auto;
    }

    .ab-feed article {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .cb-workspace,
    .ab-app {
        width: 100%;
        padding: 14px;
    }

    .cb-form-grid,
    .ab-top {
        grid-template-columns: 1fr;
    }

    .ab-top nav {
        overflow-x: auto;
        justify-content: flex-start;
    }

    .ab-phone {
        min-height: 520px;
        border-radius: 28px;
    }
}

/* Custom checkboxes */
input[type="checkbox"] {
    appearance: none !important;
    -webkit-appearance: none !important;
    display: inline-grid !important;
    place-content: center;
    flex: 0 0 auto;
    width: 20px !important;
    min-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(154, 170, 185, .44) !important;
    border-radius: 7px !important;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .015)),
        rgba(9, 16, 22, .92) !important;
    color: currentColor;
    cursor: pointer;
    box-shadow: inset 0 1px rgba(255, 255, 255, .05);
    transition: background .16s ease, border-color .16s ease, box-shadow .16s ease, transform .16s ease;
    vertical-align: -4px;
}

input[type="checkbox"]::before {
    content: "";
    width: 6px;
    height: 11px;
    border: solid #03110b;
    border-width: 0 2px 2px 0;
    opacity: 0;
    transform: rotate(45deg) scale(.6);
    transition: opacity .12s ease, transform .12s ease;
}

input[type="checkbox"]:checked {
    border-color: rgba(103, 216, 166, .95) !important;
    background: linear-gradient(135deg, #67d8a6, #2fbf83) !important;
    box-shadow: 0 0 0 4px rgba(47, 191, 131, .14), 0 10px 26px rgba(47, 191, 131, .18);
}

input[type="checkbox"]:checked::before {
    opacity: 1;
    transform: rotate(45deg) scale(1);
}

input[type="checkbox"]:focus-visible {
    outline: 3px solid rgba(47, 191, 131, .22) !important;
    outline-offset: 2px;
}

input[type="checkbox"]:disabled {
    opacity: .45;
    cursor: not-allowed;
}

label:has(input[type="checkbox"]) {
    display: flex !important;
    align-items: center;
    gap: 10px;
    line-height: 1.35;
}

.citadel-app input[type="checkbox"] {
    border-color: rgba(184, 219, 204, .28) !important;
    border-radius: 8px !important;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .02)),
        rgba(5, 12, 10, .84) !important;
}

.citadel-app input[type="checkbox"]:checked {
    border-color: rgba(103, 216, 166, .95) !important;
    background: linear-gradient(135deg, #67d8a6, #60a5fa) !important;
}

.alphach-app input[type="checkbox"] {
    border-color: rgba(255, 255, 255, .20) !important;
    border-radius: 9px !important;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02)),
        rgba(255, 255, 255, .07) !important;
}

.alphach-app input[type="checkbox"]:checked {
    border-color: rgba(255, 54, 95, .95) !important;
    background: linear-gradient(135deg, #ff365f, #ffd647) !important;
    box-shadow: 0 0 0 4px rgba(255, 54, 95, .16), 0 10px 26px rgba(255, 54, 95, .22);
}

/* Modern dark Citadel redesign */
.citadel-app {
    background:
        radial-gradient(circle at 18% 8%, rgba(47, 191, 131, .22), transparent 30%),
        radial-gradient(circle at 88% 18%, rgba(96, 165, 250, .16), transparent 28%),
        linear-gradient(180deg, #06100d 0%, #09110f 44%, #050807 100%);
    color: #e7f3ee;
    font-family: Inter, Arial, sans-serif;
}

.citadel-app input,
.citadel-app select,
.citadel-app textarea {
    border: 1px solid rgba(184, 219, 204, .18) !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, .055) !important;
    color: #e7f3ee !important;
    font-family: Inter, Arial, sans-serif !important;
}

.citadel-app option {
    background: #0c1713;
    color: #e7f3ee;
}

.citadel-app .bank-notify-anchor {
    background: rgba(12, 23, 19, .78);
    border: 1px solid rgba(184, 219, 204, .16);
}

.cb-shell {
    grid-template-columns: 250px minmax(0, 1fr);
}

.cb-rail {
    background: rgba(5, 12, 10, .88);
    border-right: 1px solid rgba(184, 219, 204, .13);
    color: #e7f3ee;
    backdrop-filter: blur(20px);
}

.cb-seal {
    width: 72px;
    height: 72px;
    border: 1px solid rgba(103, 216, 166, .5);
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(103, 216, 166, .22), rgba(96, 165, 250, .12));
    color: #67d8a6 !important;
    box-shadow: 0 18px 50px rgba(47, 191, 131, .14);
}

.cb-rail nav a {
    padding: 12px 14px;
    border: 1px solid transparent;
    border-radius: 14px;
    color: rgba(231, 243, 238, .76) !important;
}

.cb-rail nav a:hover {
    border-color: rgba(103, 216, 166, .22);
    background: rgba(255, 255, 255, .06);
    color: #fff !important;
}

.cb-rail-note {
    color: #67d8a6 !important;
}

.cb-workspace {
    gap: 18px;
    padding: 26px;
}

.cb-hero,
.cb-register-grid article,
.cb-paper,
.cb-service-panel,
.cb-card-vault,
.cb-history,
.cb-danger-zone,
.cb-dialog {
    border: 1px solid rgba(184, 219, 204, .14);
    border-radius: 26px;
    background: rgba(13, 24, 21, .82);
    color: #e7f3ee;
    box-shadow: inset 0 1px rgba(255, 255, 255, .055), 0 22px 70px rgba(0, 0, 0, .25);
    backdrop-filter: blur(18px);
}

.cb-hero {
    min-height: 330px;
    background:
        linear-gradient(135deg, rgba(47, 191, 131, .20), rgba(96, 165, 250, .08) 48%, rgba(255, 255, 255, .035)),
        rgba(13, 24, 21, .86);
    overflow: hidden;
}

.cb-hero h1,
.cb-paper h2,
.cb-service-panel h2,
.cb-card-vault h2,
.cb-history h2,
.cb-danger-zone h2,
.cb-dialog h2 {
    color: #f5fff9;
    font-family: Inter, Arial, sans-serif;
}

.cb-hero span,
.cb-register-grid small,
.cb-service-panel small,
.cb-card-grid p,
.cb-table small,
.cb-danger-zone p,
.cb-balance-book em,
.cb-empty {
    color: rgba(231, 243, 238, .62);
}

.cb-hero p,
.cb-paper-head span,
.cb-section-head span,
.cb-balance-book small,
.cb-register-grid span,
.cb-dialog-head span {
    color: #67d8a6;
    font-family: Inter, Arial, sans-serif;
    letter-spacing: .06em;
}

.cb-balance-book {
    border: 1px solid rgba(103, 216, 166, .24);
    border-radius: 24px;
    background:
        radial-gradient(circle at 90% 0%, rgba(103, 216, 166, .26), transparent 36%),
        rgba(5, 12, 10, .78);
    color: #e7f3ee;
}

.cb-balance-book strong,
.cb-register-grid strong,
.cb-cashback-row strong,
.cb-card-grid h3 {
    color: #67d8a6;
}

.cb-alert {
    border: 1px solid rgba(103, 216, 166, .24);
    border-left: 5px solid #67d8a6;
    border-radius: 18px;
    background: rgba(13, 24, 21, .88);
    color: #e7f3ee;
}

.cb-alert.error {
    border-color: rgba(248, 113, 113, .5);
    border-left-color: #f87171;
}

.cb-service-list span {
    border-left: 0;
    border-radius: 14px;
    background: rgba(255, 255, 255, .06);
    color: #e7f3ee;
}

.cb-cashback-row {
    border-bottom: 1px solid rgba(184, 219, 204, .10);
}

.cb-card-grid article {
    border: 1px solid rgba(103, 216, 166, .20);
    border-radius: 24px;
    background:
        linear-gradient(135deg, rgba(103, 216, 166, .24), rgba(96, 165, 250, .10)),
        #08110e;
    color: #e7f3ee;
}

.cb-danger-zone {
    border-color: rgba(248, 113, 113, .34);
    background: rgba(45, 14, 18, .72);
}

.cb-table table {
    color: #e7f3ee;
}

.cb-table th,
.cb-table td {
    border-bottom: 1px solid rgba(184, 219, 204, .10);
}

.cb-table th {
    background: rgba(255, 255, 255, .06);
    color: rgba(231, 243, 238, .70);
}

.cb-table td span {
    border: 1px solid rgba(103, 216, 166, .24);
    border-radius: 999px;
    background: rgba(103, 216, 166, .10);
    color: #bff4d6;
}

.cb-primary,
.cb-secondary,
.cb-danger-zone button,
.cb-dialog button {
    min-height: 44px;
    border: 0 !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #67d8a6, #60a5fa) !important;
    color: #03110b !important;
    font-family: Inter, Arial, sans-serif !important;
    font-weight: 900 !important;
}

.cb-secondary,
.cb-dialog button[type="button"] {
    border: 1px solid rgba(184, 219, 204, .16) !important;
    background: rgba(255, 255, 255, .07) !important;
    color: #e7f3ee !important;
}

.cb-card-options label {
    border: 1px solid rgba(184, 219, 204, .14);
    border-radius: 18px;
    background: rgba(255, 255, 255, .06);
}

.cb-dialog::backdrop {
    background: rgba(0, 0, 0, .72);
}

/* Keep checkboxes isolated from broad input theme overrides. */
input[type="checkbox"],
.citadel-app input[type="checkbox"],
.alphach-app input[type="checkbox"] {
    appearance: none !important;
    -webkit-appearance: none !important;
    display: inline-grid !important;
    place-content: center;
    flex: 0 0 auto;
    width: 20px !important;
    min-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    cursor: pointer;
    vertical-align: -4px;
}

.citadel-app input[type="checkbox"] {
    border: 1px solid rgba(184, 219, 204, .28) !important;
    border-radius: 8px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .02)), rgba(5, 12, 10, .84) !important;
}

.alphach-app input[type="checkbox"] {
    border: 1px solid rgba(255, 255, 255, .20) !important;
    border-radius: 9px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02)), rgba(255, 255, 255, .07) !important;
}

.citadel-app input[type="checkbox"]:checked {
    border-color: rgba(103, 216, 166, .95) !important;
    background: linear-gradient(135deg, #67d8a6, #60a5fa) !important;
}

.alphach-app input[type="checkbox"]:checked {
    border-color: rgba(255, 54, 95, .95) !important;
    background: linear-gradient(135deg, #ff365f, #ffd647) !important;
}

/* Citadel final palette: dark green only, no light paper theme. */
.citadel-app {
    background: linear-gradient(180deg, #020705 0%, #07130e 46%, #010403 100%) !important;
    color: #d8efe3 !important;
}

.citadel-app input,
.citadel-app select,
.citadel-app textarea {
    border-color: #1d4d38 !important;
    background: #06120d !important;
    color: #d8efe3 !important;
}

.citadel-app option {
    background: #06120d !important;
    color: #d8efe3 !important;
}

.citadel-app .bank-notify-anchor,
.cb-rail,
.cb-hero,
.cb-register-grid article,
.cb-paper,
.cb-service-panel,
.cb-card-vault,
.cb-history,
.cb-danger-zone,
.cb-dialog,
.cb-balance-book,
.cb-card-grid article {
    border-color: #1d4d38 !important;
    background: #081710 !important;
    color: #d8efe3 !important;
    box-shadow: 0 18px 54px rgba(0, 0, 0, .34) !important;
}

.cb-rail {
    background: #030a07 !important;
}

.cb-hero {
    background: linear-gradient(135deg, #0c2619, #06120d 58%, #020705) !important;
}

.cb-seal,
.cb-rail nav a:hover,
.cb-currency-strip span,
.cb-mini-service,
.cb-service-list span,
.cb-system-link,
.cb-card-options label,
.cb-table th,
.cb-table td span {
    border-color: #246345 !important;
    background: #0b2116 !important;
    color: #d8efe3 !important;
}

.cb-hero h1,
.cb-paper h2,
.cb-service-panel h2,
.cb-card-vault h2,
.cb-history h2,
.cb-danger-zone h2,
.cb-dialog h2,
.cb-register-grid strong {
    color: #e7fff2 !important;
}

.cb-hero p,
.cb-paper-head span,
.cb-section-head span,
.cb-balance-book small,
.cb-register-grid span,
.cb-dialog-head span,
.cb-balance-book strong,
.cb-cashback-row strong,
.cb-cashback-rule span,
.cb-mini-service > span,
.cb-card-grid h3,
.cb-rail-note,
.cb-seal {
    color: #42b883 !important;
}

.cb-hero span,
.cb-register-grid small,
.cb-service-panel small,
.cb-card-grid p,
.cb-table small,
.cb-danger-zone p,
.cb-balance-book em,
.cb-empty,
.cb-mini-service small,
.cb-cashback-rule small,
.cb-auto-note {
    color: #8db8a3 !important;
}

.cb-alert {
    border-color: #246345 !important;
    border-left-color: #42b883 !important;
    background: #0b2116 !important;
    color: #d8efe3 !important;
}

.cb-alert.error,
.cb-danger-zone {
    border-color: #6b2c31 !important;
    background: #1c0d0f !important;
}

.cb-cashback-row,
.cb-table th,
.cb-table td {
    border-bottom-color: #163827 !important;
}

.cb-primary,
.cb-secondary,
.cb-danger-zone button,
.cb-dialog button {
    border: 1px solid #42b883 !important;
    background: #0f3a28 !important;
    color: #e7fff2 !important;
}

.cb-secondary,
.cb-dialog button[type="button"] {
    background: #06120d !important;
    color: #d8efe3 !important;
}

.citadel-app input[type="checkbox"],
.citadel-app input[type="checkbox"]:checked {
    border-color: #246345 !important;
    background: #0f3a28 !important;
}

/* Citadel service blocks now sit in the main flow instead of hanging on the far right. */
.citadel-app .cb-workspace {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
}

.citadel-app .cb-ledger-layout {
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
}

.citadel-app .cb-stack {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
}

.citadel-app .cb-right-column {
    grid-template-columns: repeat(3, minmax(220px, 1fr));
    width: 100%;
}

.citadel-app .cb-service-panel {
    min-height: 100%;
}

.citadel-app .cb-document-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: 1180px;
    margin-right: auto;
    margin-left: auto;
}

@media (max-width: 1180px) {
    .citadel-app .cb-right-column,
    .citadel-app .cb-document-grid {
        grid-template-columns: 1fr;
    }

    .citadel-app .cb-stack {
        max-width: none;
    }
}

/* Cleaner standard portal layout: less visual noise, tighter reading flow. */
.rp-shell {
    gap: 18px;
}

.rp-page-head,
.rp-panel,
.rp-card,
.card,
.mod-item,
.stat-box,
.table-item,
.info-box,
.download-section {
    border-radius: 8px !important;
    box-shadow: none !important;
}

.rp-page-head {
    align-items: center;
    padding: 20px;
}

.rp-page-head,
.rp-panel,
.rp-card,
.card,
.mod-item,
.stat-box,
.table-item,
.info-box,
.download-section,
.rp-table-wrap {
    border-color: var(--line) !important;
    background: var(--surface) !important;
}

.rp-panel,
.rp-card,
.card,
.mod-item,
.stat-box,
.table-item,
.info-box {
    padding: 16px !important;
}

.container {
    gap: 18px;
}

.rp-grid {
    gap: 12px;
}

.rp-section-title {
    margin: 18px 0 10px;
}

.rp-section-title h2,
.rp-card h3,
.rp-card h4,
.rp-panel h2 {
    margin-top: 0;
}

.rp-card p,
.rp-lead {
    max-width: 820px;
}

.rp-list {
    gap: 0;
}

.rp-list li {
    padding: 8px 0;
    border-bottom-color: var(--line-soft);
}

.rp-table-wrap {
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: auto;
}

table th,
table td {
    padding: 10px 12px;
}

.form-grid {
    gap: 12px;
}

.message {
    border-radius: 8px;
    box-shadow: none;
}

.rp-vacancy-card {
    display: flex;
    flex-direction: column;
}

.rp-vacancy-card .rp-list {
    margin-top: auto;
}

.vacancy-actions {
    margin-top: 14px;
}

.vacancy-actions .rp-btn {
    width: 100%;
    justify-content: center;
}

/* Alphach refresh: calmer dark interface with clearer panels and controls. */
.alphach-app,
.alphach-app .ab-app {
    background: #11070a !important;
    color: #fff4f6 !important;
}

.ab-top,
.ab-phone,
.ab-metrics article,
.ab-glass-form,
.ab-transfer,
.ab-ai-card,
.ab-products,
.ab-service-panel,
.ab-card-store,
.ab-rewards,
.ab-feed,
.ab-side-forms form,
.ab-debt-row,
.ab-business-account-card {
    border: 1px solid rgba(255, 95, 122, .22) !important;
    border-radius: 8px !important;
    background: #190b10 !important;
    box-shadow: none !important;
}

.ab-top {
    position: sticky;
    top: 0;
    z-index: 20;
    backdrop-filter: blur(14px);
}

.ab-logo,
.ab-top nav button.active,
.ab-fast-actions button,
.ab-glass-form button,
.ab-transfer button,
.ab-card-store button,
.ab-side-forms button {
    border-radius: 8px !important;
    background: #ff365f !important;
    color: #fff !important;
}

.ab-top nav button,
.ab-top > a,
.ab-fields input,
.ab-fields select,
.ab-fields textarea,
.ab-service-panel input,
.ab-service-panel select,
.ab-service-panel textarea,
.ab-service-panel button,
.ab-transfer input,
.ab-transfer select,
.ab-transfer textarea,
.ab-side-forms select,
.ab-side-forms textarea {
    border: 1px solid rgba(255, 95, 122, .24) !important;
    border-radius: 8px !important;
    background: #220d14 !important;
    color: #fff4f6 !important;
}

.ab-panel,
.ab-dashboard,
.ab-pay-grid,
.ab-market,
.ab-systems-layout,
.ab-feed-layout {
    gap: 14px !important;
}

.ab-phone-top span,
.ab-balance small,
.ab-metrics span,
.ab-ai-card span,
.ab-card-store span,
.ab-rewards small,
.ab-feed article span,
.ab-empty,
.ab-debt-row small,
.ab-service-panel small {
    color: #ff9daf !important;
}

.ab-balance strong,
.ab-products h1,
.ab-transfer h1,
.ab-feed h1,
.ab-card-store h2,
.ab-rewards h2,
.ab-service-panel h2,
.ab-debt-row strong {
    color: #fff !important;
}

.ab-debt-filters,
.ab-autopay-form,
.ab-debt-list {
    display: grid;
    gap: 10px;
}

.ab-debt-filters {
    display: flex;
    flex-wrap: wrap;
}

.ab-debt-filters button,
.ab-business-open {
    border: 1px solid rgba(255, 95, 122, .24) !important;
    border-radius: 8px !important;
    background: #220d14 !important;
    color: #fff4f6 !important;
    text-decoration: none;
}

.ab-debt-filters button.active,
.ab-debt-row button,
.ab-business-open {
    background: #ff365f !important;
    color: #fff !important;
}

.bank-business-page {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 76px 0 32px;
}

.bank-business-page .cb-top,
.bank-business-page .ab-top {
    margin-bottom: 16px;
}

.bank-business-page .cb-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border: 1px solid #1d4d38 !important;
    border-radius: 8px !important;
    background: #081710 !important;
    padding: 12px;
}

.bank-business-page .cb-top nav,
.bank-business-page .ab-top nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cb-business-open,
.ab-business-open {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 8px 12px;
    font-weight: 800;
}

.cb-business-open {
    border: 1px solid #42b883 !important;
    border-radius: 8px !important;
    background: #0f3a28 !important;
    color: #e7fff2 !important;
    text-decoration: none;
}

/* Full portal visual refresh: clearer rhythm, calmer surfaces, better scanning. */
:root {
    --bg: #080b10;
    --surface: #101720;
    --surface-2: #151e28;
    --surface-3: #1b2632;
    --elevated: #121c27;
    --ink: #f2f6f8;
    --muted: #a5b1bc;
    --faint: #74818d;
    --line: #293746;
    --line-soft: rgba(255, 255, 255, .08);
    --accent: #35c889;
    --accent-2: #7bdcad;
    --blue: #75aefc;
    --warn: #f0bf5a;
    --danger: #ef7777;
    --shadow: 0 18px 48px rgba(0, 0, 0, .28);
    --shadow-soft: 0 10px 26px rgba(0, 0, 0, .16);
}

body:not(.citadel-app):not(.alphach-app) {
    background:
        linear-gradient(180deg, #080b10 0%, #0b1118 46%, #080b10 100%) !important;
}

body:not(.citadel-app):not(.alphach-app)::before {
    opacity: .28;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .035), transparent 34%),
        linear-gradient(90deg, rgba(255, 255, 255, .018) 1px, transparent 1px);
    background-size: auto, 72px 72px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.78), transparent 58%);
}

.rp-shell,
.container,
.rp-container {
    display: grid;
    gap: 16px;
    max-width: 1440px !important;
    padding: 24px 30px 64px !important;
}

.rp-topbar,
.navbar {
    background: #0a1017 !important;
    border-color: #1f2a36 !important;
}

.rp-brand,
.navbar h1 {
    border-bottom-color: #1f2a36 !important;
}

.rp-brand-mark {
    background: linear-gradient(135deg, var(--accent), var(--blue));
    color: #06100c;
}

.rp-nav,
.navbar-right {
    gap: 5px !important;
}

.rp-nav .rp-btn,
.navbar-right a {
    min-height: 38px;
    padding: 9px 10px !important;
    border-radius: 8px !important;
}

.rp-nav .rp-btn:hover,
.navbar-right a:hover,
.rp-nav .rp-btn.active {
    background: #121b25 !important;
    border-color: #263646 !important;
}

.rp-page-head {
    align-items: center;
    margin-bottom: 4px;
    padding: 22px !important;
    border-color: #2b3a49 !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.026), transparent 72%),
        var(--surface) !important;
}

.rp-page-head h1 {
    max-width: 960px;
    font-size: clamp(28px, 3vw, 44px) !important;
    letter-spacing: 0 !important;
}

.rp-lead,
.rp-page-head p {
    color: var(--muted);
}

.rp-eyebrow {
    color: var(--accent-2) !important;
    letter-spacing: .08em !important;
}

.rp-grid {
    gap: 14px !important;
}

.rp-panel,
.rp-card,
.card,
.mod-item,
.stat-box,
.table-item,
.info-box,
.download-section {
    border: 1px solid #2a3847 !important;
    border-radius: 10px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.022), transparent 76%),
        var(--surface) !important;
    box-shadow: none !important;
}

.rp-panel,
.card {
    padding: 18px !important;
}

.rp-card,
.mod-item,
.stat-box,
.table-item,
.info-box {
    padding: 16px !important;
}

.rp-card:hover,
.rp-service-link:hover,
.bank-choice-card:hover {
    transform: none !important;
    border-color: rgba(53, 200, 137, .38) !important;
    background:
        linear-gradient(180deg, rgba(53,200,137,.04), transparent 70%),
        var(--surface-2) !important;
}

.rp-section-title {
    align-items: center;
    margin: 12px 0 6px !important;
}

.rp-section-title h2,
.rp-panel h2,
.card h2,
.container h2 {
    font-size: clamp(20px, 1.6vw, 28px) !important;
    line-height: 1.18 !important;
}

.rp-card h3,
.rp-card h4 {
    line-height: 1.25;
}

.rp-kpi {
    align-items: center;
}

.rp-kpi p,
.rp-kpi span,
.rp-muted {
    color: var(--muted) !important;
}

.rp-list li {
    align-items: flex-start;
    padding: 9px 0 !important;
    border-bottom-color: rgba(255, 255, 255, .075) !important;
}

.rp-list strong {
    min-width: 120px;
}

.rp-list span {
    color: #c4ced6;
}

.rp-table-wrap {
    border-color: #2a3847 !important;
    border-radius: 10px !important;
    background: #0d141c !important;
}

table {
    min-width: 720px;
}

table thead {
    background: #162230 !important;
}

table th {
    color: #c4d0da !important;
    letter-spacing: .06em;
}

table th,
table td {
    padding: 11px 12px !important;
    border-bottom-color: rgba(255, 255, 255, .075) !important;
}

table tbody tr:nth-child(even) {
    background: rgba(255, 255, 255, .012);
}

table tbody tr:hover {
    background: rgba(53, 200, 137, .07) !important;
}

.form-grid {
    gap: 12px 14px !important;
}

.form-group {
    margin-bottom: 10px !important;
}

label,
.form-group label,
.business-control-card label,
.rp-compact-form label {
    color: #d5dee6 !important;
    font-size: 12px !important;
    font-weight: 850 !important;
}

input,
textarea,
select {
    min-height: 42px;
    border-color: #314151 !important;
    background: #0b121a !important;
    color: var(--ink) !important;
}

textarea {
    line-height: 1.55;
}

input::placeholder,
textarea::placeholder {
    color: #667583;
}

input:hover,
textarea:hover,
select:hover {
    border-color: #3a4f62 !important;
}

input:focus,
textarea:focus,
select:focus {
    border-color: rgba(53, 200, 137, .72) !important;
    outline: 3px solid rgba(53, 200, 137, .18) !important;
}

input[readonly] {
    background:
        linear-gradient(90deg, rgba(53, 200, 137, .22) 0 4px, #101923 4px 100%) !important;
}

details:not(.rp-nav-group) {
    border-color: #2a3847 !important;
    background: #0d141c !important;
}

details:not(.rp-nav-group) summary {
    cursor: pointer;
    color: var(--ink);
    font-weight: 850;
}

.rp-btn,
.btn,
button {
    min-height: 40px;
    border-radius: 8px !important;
    box-shadow: none !important;
}

.rp-btn:not(.secondary):not(.disabled),
.btn:not(.btn-secondary),
button:not(:disabled) {
    background: linear-gradient(135deg, var(--accent), #55d69b) !important;
}

.rp-btn.secondary,
.btn-secondary {
    background: #172230 !important;
    border-color: #304153 !important;
}

.rp-btn.disabled,
.rp-btn:disabled,
button:disabled {
    opacity: .62 !important;
    filter: grayscale(.15);
}

.rp-chip {
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.10);
}

.message {
    border: 1px solid #2a3847;
    background: #101820;
}

.message.success {
    border-color: rgba(53, 200, 137, .35) !important;
    background: rgba(53, 200, 137, .10) !important;
}

.message.error {
    border-color: rgba(239, 119, 119, .42) !important;
    background: rgba(239, 119, 119, .10) !important;
}

.bank-choice-grid,
.bank-rule-grid {
    gap: 14px !important;
}

.bank-choice-card {
    display: grid;
    gap: 14px;
}

.bank-cashback-strip {
    gap: 8px;
}

.business-tabs {
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: rgba(255,255,255,.018);
}

.business-control-card {
    background:
        linear-gradient(180deg, rgba(255,255,255,.018), transparent 70%),
        #121b25 !important;
}

.notification-popup {
    border-radius: 10px;
}

@media (max-width: 1180px) {
    :root {
        --sidebar: 248px;
    }

    .rp-shell,
    .container,
    .rp-container {
        padding: 20px 20px 56px !important;
    }

    .rp-col-3,
    .rp-col-4,
    .rp-col-5,
    .rp-col-6 {
        grid-column: span 6;
    }

    .rp-col-7,
    .rp-col-8 {
        grid-column: span 12;
    }
}

@media (max-width: 860px) {
    body:not(.citadel-app):not(.alphach-app) {
        padding-bottom: 0;
    }

    .navbar,
    .rp-topbar {
        position: sticky !important;
        inset: 0 auto auto 0 !important;
        width: 100% !important;
        height: auto !important;
        max-height: 72vh;
        overflow-y: auto;
        border-right: 0 !important;
        border-bottom: 1px solid var(--line) !important;
    }

    .rp-shell,
    .container,
    .rp-container,
    body.rp-nav-right .rp-shell,
    body.rp-nav-right .container,
    body.rp-nav-right .rp-container {
        margin: 0 !important;
        padding: 16px 14px 44px !important;
    }

    .rp-page-head {
        align-items: stretch;
        flex-direction: column;
        padding: 18px !important;
    }

    .rp-page-head > .rp-btn,
    .rp-page-head > form,
    .rp-page-head > form .rp-btn {
        width: 100%;
    }

    .form-grid,
    .bank-choice-grid,
    .bank-rule-grid {
        grid-template-columns: 1fr !important;
    }

    .rp-col-3,
    .rp-col-4,
    .rp-col-5,
    .rp-col-6,
    .rp-col-7,
    .rp-col-8,
    .rp-col-12 {
        grid-column: span 12;
    }

    .rp-list li {
        display: grid;
        gap: 4px;
    }

    .rp-list span {
        text-align: left;
    }

    table {
        min-width: 680px;
    }
}

@media (max-width: 560px) {
    body {
        font-size: 13px;
    }

    .rp-page-head h1 {
        font-size: 27px !important;
    }

    .rp-panel,
    .rp-card,
    .card {
        padding: 14px !important;
    }

    .rp-btn,
    .btn,
    button {
        width: 100%;
    }

    .rp-inline-actions,
    .rp-actions,
    .rp-action-row,
    .rp-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }
}

/* Rebuilt business panel */
.business-hero,
.business-empty-state,
.business-switcher,
.business-profile,
.business-register,
.business-market,
.business-data-grid > article,
.business-tool {
    border: 1px solid var(--line);
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.026), transparent 74%),
        var(--surface);
}

.business-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 18px;
    align-items: stretch;
    padding: 24px;
}

.business-hero h1 {
    margin: 0;
    font-size: clamp(34px, 4vw, 58px);
    letter-spacing: 0;
}

.business-hero p {
    max-width: 820px;
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.business-license-card {
    display: grid;
    align-content: center;
    gap: 8px;
    padding: 18px;
    border: 1px solid rgba(53, 200, 137, .28);
    border-radius: 10px;
    background: rgba(53, 200, 137, .09);
}

.business-license-card span,
.business-dashboard span,
.business-metrics span,
.business-tool-head span {
    color: var(--accent-2);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.business-license-card strong {
    font-size: 20px;
}

.business-license-card small {
    color: var(--muted);
}

.business-empty-state {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding: 24px;
}

.business-empty-state h2,
.business-switcher h2,
.business-profile h2,
.business-register h2,
.business-market h2 {
    margin: 0;
}

.business-empty-state p {
    max-width: 720px;
    color: var(--muted);
}

.business-dashboard,
.business-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.business-dashboard article,
.business-metrics article {
    display: grid;
    gap: 6px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface);
}

.business-dashboard strong,
.business-metrics strong {
    font-size: clamp(24px, 2.4vw, 34px);
    line-height: 1;
}

.business-dashboard small,
.business-metrics small {
    color: var(--muted);
}

.business-switcher {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    padding: 16px;
}

.business-switcher nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.business-switcher a {
    display: inline-flex;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
    color: var(--ink);
    font-weight: 800;
    text-decoration: none;
}

.business-switcher a.active {
    border-color: rgba(53, 200, 137, .45);
    background: rgba(53, 200, 137, .14);
    color: var(--accent-2);
}

.business-profile {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
    gap: 18px;
    padding: 20px;
}

.business-profile p {
    color: var(--muted);
}

.business-profile ul {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.business-profile li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--line-soft);
}

.business-profile li span {
    color: var(--muted);
}

.business-workspace {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.business-action-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.business-action-strip a {
    display: grid;
    gap: 5px;
    width: 100%;
    padding: 14px 16px;
    border: 1px solid rgba(53, 200, 137, .35);
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(53, 200, 137, .18), rgba(97, 218, 251, .1));
    color: var(--ink);
    text-align: left;
    text-decoration: none;
}

.business-action-strip a:hover,
.business-action-strip a.is-active {
    border-color: rgba(53, 200, 137, .75);
    transform: translateY(-1px);
}

.business-action-strip span {
    color: var(--muted);
    font-size: 12px;
}

.business-action-strip strong {
    font-size: 15px;
}

.business-direct-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.business-direct-actions details {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(53, 200, 137, .35);
    border-radius: 12px;
    background: var(--surface);
}

.business-direct-actions summary {
    min-height: 42px;
    cursor: pointer;
    color: var(--ink);
    font-size: 16px;
    font-weight: 900;
}

.business-direct-actions details[open] summary {
    margin-bottom: 12px;
    color: var(--accent-2);
}

.business-tool {
    display: grid;
    align-content: start;
    gap: 14px;
    padding: 16px;
    scroll-margin-top: 96px;
}

.business-tool:target,
.business-tool.is-focused {
    border-color: rgba(53, 200, 137, .75);
    box-shadow: 0 0 0 3px rgba(53, 200, 137, .12), 0 18px 48px rgba(10, 17, 28, .24);
}

.business-tool-wide {
    grid-column: span 4;
}

.business-tool-head {
    display: grid;
    gap: 4px;
}

.business-tool-head h3,
.business-data-grid h3,
.business-market-grid h3 {
    margin: 0;
}

.business-mini-form,
.business-rules-form {
    display: grid;
    gap: 10px;
}

.business-rules-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.business-rules-form button {
    grid-column: 1 / -1;
}

.business-mini-form label,
.business-rules-form label {
    display: grid;
    gap: 6px;
    color: var(--muted) !important;
}

.business-mini-form label span,
.business-rules-form label span {
    color: var(--ink);
}

.business-mini-form textarea,
.business-rules-form textarea {
    min-height: 82px;
}

.business-list {
    display: grid;
    gap: 8px;
}

.business-list a {
    display: grid;
    gap: 3px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
    color: var(--ink);
    text-decoration: none;
}

.business-list a:hover {
    border-color: rgba(53, 200, 137, .4);
}

.business-list span {
    color: var(--muted);
    font-size: 12px;
}

.business-data-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.business-data-grid > article,
.business-register,
.business-market {
    display: grid;
    gap: 12px;
    padding: 16px;
}

.business-market-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.business-market-grid article {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--surface-2);
}

.business-market-grid p {
    margin: 0;
    color: var(--muted);
}

.business-market-grid strong {
    color: var(--accent-2);
}

@media (max-width: 1280px) {
    .business-workspace,
    .business-dashboard,
    .business-metrics,
    .business-action-strip,
    .business-direct-actions,
    .business-market-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .business-tool-wide {
        grid-column: span 2;
    }
}

@media (max-width: 900px) {
    .business-hero,
    .business-switcher,
    .business-profile,
    .business-data-grid,
    .business-rules-form {
        grid-template-columns: 1fr;
    }

    .business-dashboard,
    .business-metrics,
    .business-action-strip,
    .business-direct-actions,
    .business-workspace,
    .business-market-grid {
        grid-template-columns: 1fr;
    }

    .business-tool-wide {
        grid-column: span 1;
    }

    .business-empty-state {
        align-items: stretch;
        flex-direction: column;
    }
}

/* Business OS page */
.biz-os-hero,
.biz-os-empty,
.biz-os-switcher,
.biz-os-console,
.biz-os-market,
.biz-os-register,
.biz-os-journals > article {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.biz-os-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 18px;
    padding: 24px;
    background: linear-gradient(120deg, rgba(53, 200, 137, .13), transparent 48%), #09111a;
}

.biz-os-hero h1 {
    margin: 0;
    font-size: clamp(38px, 5vw, 72px);
    letter-spacing: 0;
}

.biz-os-hero p {
    max-width: 860px;
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.biz-os-hero aside {
    display: grid;
    align-content: center;
    gap: 8px;
    padding: 18px;
    border: 1px solid rgba(53, 200, 137, .34);
    border-radius: 6px;
    background: #06100e;
    box-shadow: inset 5px 0 0 rgba(53, 200, 137, .82);
}

.biz-os-hero aside span,
.biz-os-stats span,
.biz-os-switcher span,
.biz-panel-head span,
.biz-os-kpis span {
    color: var(--accent-2);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.biz-os-hero aside strong {
    font-size: 22px;
}

.biz-os-empty {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 24px;
}

.biz-os-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--line);
}

.biz-os-stats article {
    display: grid;
    gap: 6px;
    padding: 16px;
    background: #0b131d;
}

.biz-os-stats strong,
.biz-os-kpis strong {
    font-size: clamp(24px, 2.6vw, 36px);
    line-height: 1;
}

.biz-os-stats small,
.biz-os-kpis small {
    color: var(--muted);
}

.biz-os-switcher {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 14px;
    background: #101923;
}

.biz-os-switcher > div {
    display: grid;
    gap: 6px;
}

.biz-os-switcher nav {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px;
}

.biz-os-switcher a {
    display: flex;
    min-height: 40px;
    align-items: center;
    padding: 8px 12px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #08111b;
    color: var(--ink);
    font-weight: 900;
    text-decoration: none;
}

.biz-os-switcher a.active {
    border-color: rgba(53, 200, 137, .72);
    color: var(--accent-2);
}

.biz-os-console {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    min-height: 720px;
    overflow: hidden;
    background: #070c13;
}

.biz-os-sidebar {
    display: grid;
    align-content: start;
    border-right: 1px solid var(--line);
    background: #08111b;
}

.biz-os-passport {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-bottom: 1px solid var(--line);
}

.biz-os-passport h2 {
    margin: 0;
    font-size: 30px;
    line-height: 1.05;
}

.biz-os-passport p,
.biz-os-ledger p,
.biz-os-market p {
    margin: 0;
    color: var(--muted);
}

.biz-os-passport dl {
    display: grid;
    gap: 1px;
    margin: 0;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: var(--line);
}

.biz-os-passport dl div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px;
    background: #0b131d;
}

.biz-os-passport dt {
    color: var(--muted);
}

.biz-os-passport dd {
    margin: 0;
    font-weight: 900;
    text-align: right;
}

.biz-os-nav {
    display: grid;
    padding: 10px;
    gap: 6px;
}

.biz-os-nav a {
    display: flex;
    min-height: 42px;
    align-items: center;
    padding: 9px 12px;
    border: 1px solid transparent;
    border-radius: 4px;
    background: transparent;
    color: var(--ink);
    font: inherit;
    font-weight: 900;
    text-decoration: none;
    text-align: left;
    cursor: pointer;
}

.biz-os-nav a:hover,
.biz-os-nav a.active {
    border-color: rgba(53, 200, 137, .5);
    background: rgba(53, 200, 137, .12);
    color: var(--accent-2);
}

.biz-os-stage {
    display: grid;
    align-content: start;
    gap: 14px;
    padding: 14px;
}

.biz-os-kpis,
.biz-os-ledger,
.biz-os-journals,
.biz-os-market > div:last-child {
    display: grid;
    gap: 12px;
}

.biz-os-kpis {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.biz-os-kpis article,
.biz-panel,
.biz-os-ledger article {
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #0b131d;
}

.biz-os-kpis article {
    display: grid;
    gap: 5px;
    padding: 14px;
}

.biz-panel {
    display: none;
    overflow: hidden;
}

.biz-panel.active {
    display: block;
}

.biz-panel-head {
    padding: 16px;
    border-bottom: 1px solid var(--line);
    background: #08111b;
}

.biz-panel-head h3 {
    margin: 4px 0 0;
    font-size: 26px;
}

.biz-os-ledger {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 16px;
}

.biz-os-actions {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    padding: 0 16px 16px;
}

.biz-os-actions a {
    display: flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    padding: 9px 12px;
    border: 1px solid rgba(53, 200, 137, .42);
    border-radius: 4px;
    background: rgba(53, 200, 137, .16);
    color: var(--ink);
    font-weight: 900;
    text-align: center;
    text-decoration: none;
}

.biz-os-actions a:hover {
    border-color: rgba(53, 200, 137, .75);
    color: var(--accent-2);
}

.biz-os-ledger article {
    padding: 14px;
}

.biz-os-ledger h4 {
    margin: 0;
}

.biz-os-ledger strong {
    display: block;
    margin: 10px 0;
    font-size: 36px;
}

.biz-form {
    display: grid;
    gap: 12px;
    padding: 16px;
}

.biz-form.two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.biz-form label {
    display: grid;
    gap: 7px;
}

.biz-form label span {
    font-size: 12px;
    font-weight: 900;
}

.biz-form textarea {
    min-height: 96px;
}

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

.biz-list {
    display: grid;
    gap: 8px;
    padding: 0 16px 16px;
}

.biz-list a,
.biz-list article {
    display: grid;
    gap: 4px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #08111b;
    color: var(--ink);
    text-decoration: none;
}

.biz-list span,
.biz-list small {
    color: var(--muted);
}

.biz-os-journals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.biz-os-journals > article {
    display: grid;
    gap: 10px;
    padding: 14px;
    background: #0b131d;
}

.biz-os-journals h3,
.biz-os-market h2,
.biz-os-register h2 {
    margin: 0;
}

.biz-os-market,
.biz-os-register {
    display: grid;
    gap: 14px;
    padding: 16px;
}

.biz-os-market > div:last-child {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.biz-os-market article {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #08111b;
}

.biz-os-market strong {
    color: var(--accent-2);
}

@media (max-width: 1280px) {
    .biz-os-console {
        grid-template-columns: 1fr;
    }

    .biz-os-sidebar {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .biz-os-nav {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }

    .biz-os-ledger,
    .biz-os-actions,
    .biz-os-kpis,
    .biz-os-market > div:last-child {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .biz-os-hero,
    .biz-os-switcher,
    .biz-os-stats,
    .biz-os-kpis,
    .biz-os-ledger,
    .biz-os-actions,
    .biz-form.two-col,
    .biz-os-journals,
    .biz-os-market > div:last-child {
        grid-template-columns: 1fr;
    }

    .biz-os-empty {
        align-items: stretch;
        flex-direction: column;
    }
}

/* Business command center v2 */
.business-hero {
    grid-template-columns: minmax(0, 1fr) 320px !important;
    border-radius: 8px !important;
    background:
        linear-gradient(120deg, rgba(10, 17, 28, .96), rgba(17, 28, 40, .92)),
        repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 72px) !important;
    box-shadow: inset 0 -1px 0 rgba(255,255,255,.04);
}

.business-hero h1 {
    max-width: 680px;
    font-size: clamp(30px, 3.2vw, 48px) !important;
}

.business-license-card {
    border-radius: 6px !important;
    background: #07100f !important;
    box-shadow: inset 4px 0 0 var(--accent-2);
}

.business-dashboard {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 1px !important;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--line);
}

.business-dashboard article {
    border: 0 !important;
    border-radius: 0 !important;
    background: var(--surface-2) !important;
}

.business-switcher {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
    border-radius: 8px !important;
    background: var(--surface-2) !important;
}

.business-switcher nav {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.business-switcher a {
    justify-content: flex-start !important;
    border-radius: 4px !important;
    background: #0a121c !important;
}

.business-profile {
    grid-template-columns: minmax(0, 1.35fr) minmax(260px, .65fr) !important;
    border-radius: 8px !important;
    background:
        linear-gradient(90deg, rgba(53, 200, 137, .14), transparent 48%),
        var(--surface) !important;
    box-shadow: inset 6px 0 0 rgba(53, 200, 137, .82);
}

.business-profile h2 {
    font-size: clamp(28px, 3vw, 46px);
}

.business-profile ul {
    padding: 12px !important;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #090f17;
}

.business-metrics {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.business-metrics article {
    min-height: 104px;
    border-radius: 6px !important;
    background: #0b131d !important;
}

.business-action-strip {
    position: sticky;
    top: 76px;
    z-index: 6;
    display: grid !important;
    grid-template-columns: 220px repeat(4, minmax(0, 1fr)) !important;
    align-items: stretch;
    gap: 1px !important;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--line);
}

.business-action-intro,
.business-action-strip a {
    border: 0 !important;
    border-radius: 0 !important;
    background: #08111b !important;
}

.business-action-intro {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
}

.business-action-intro span,
.business-action-strip span {
    color: var(--accent-2) !important;
    font-size: 11px !important;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.business-action-intro strong,
.business-action-strip strong {
    font-size: 14px !important;
}

.business-action-strip a:hover,
.business-action-strip a.is-active {
    background: rgba(53, 200, 137, .13) !important;
    transform: none !important;
}

.business-direct-actions {
    display: none !important;
}

.business-workspace {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
    gap: 12px !important;
    align-items: start;
}

.business-tool {
    min-height: 0;
    border-radius: 6px !important;
    background: #0b131d !important;
}

.business-tool-wide {
    grid-column: 1 / -1 !important;
}

.business-tool-head {
    margin: -16px -16px 0;
    padding: 14px 16px;
    border-bottom: 1px solid var(--line);
    background: #08111b;
}

.business-tool-head h3 {
    font-size: 20px;
}

.business-mini-form,
.business-rules-form {
    gap: 12px !important;
}

.business-mini-form label,
.business-rules-form label {
    gap: 7px !important;
}

.business-mini-form input,
.business-mini-form select,
.business-mini-form textarea,
.business-rules-form textarea {
    border-radius: 4px !important;
}

.business-list article,
.business-list a {
    border-radius: 4px !important;
    background: #08111b !important;
}

.business-data-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.business-data-grid > article {
    min-height: 260px;
    border-radius: 6px !important;
    background: #0b131d !important;
}

.business-data-grid h3 {
    padding-bottom: 10px;
    border-bottom: 1px solid var(--line);
}

.business-market,
.business-register {
    border-radius: 8px !important;
    background: var(--surface-2) !important;
}

.business-market-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.business-market-grid article {
    border-radius: 4px !important;
    background: #08111b !important;
}

@media (max-width: 1280px) {
    .business-action-strip {
        position: static;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .business-action-intro {
        grid-column: 1 / -1;
    }

    .business-workspace,
    .business-data-grid,
    .business-market-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .business-tool-wide {
        grid-column: 1 / -1 !important;
    }
}

@media (max-width: 900px) {
    .business-hero,
    .business-switcher,
    .business-profile,
    .business-dashboard,
    .business-metrics,
    .business-action-strip,
    .business-workspace,
    .business-data-grid,
    .business-market-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Cash collection admin */
.cash-admin-shell {
    max-width: 1480px !important;
}

.cash-admin-shell .rp-page-head {
    margin-bottom: 18px !important;
}

.cash-kpi-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(145px, 1fr));
    gap: 14px;
    margin: 0 0 18px;
}

.rp-stat-card {
    display: grid;
    align-content: start;
    min-width: 0;
    min-height: 132px;
    gap: 9px;
    padding: 16px 18px;
    border: 1px solid #2a3847;
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(53, 200, 137, .055), transparent 72%),
        var(--surface);
}

.rp-stat-card span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .04em;
    line-height: 1.25;
    text-transform: uppercase;
}

.rp-stat-card strong {
    display: block;
    color: var(--ink);
    font-size: clamp(21px, 1.8vw, 30px);
    font-weight: 900;
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.rp-stat-card small {
    align-self: end;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.cash-admin-grid {
    align-items: start;
    margin-bottom: 16px;
}

.cash-admin-shell .rp-card,
.cash-admin-shell .rp-panel {
    min-width: 0;
    overflow: hidden;
}

.cash-admin-shell .rp-card h2,
.cash-admin-shell .rp-panel h2 {
    margin-bottom: 14px !important;
}

.cash-admin-shell .rp-table-wrap {
    overflow-x: auto;
}

.cash-admin-shell table {
    min-width: 920px;
}

.cash-admin-shell table td {
    overflow-wrap: anywhere;
}

.cash-admin-shell .rp-muted {
    overflow-wrap: anywhere;
}

.cash-admin-shell .rp-compact-form {
    min-width: 220px;
}

.cash-admin-shell .rp-compact-form .rp-btn {
    width: 100%;
}

.cash-toolbar {
    display: grid;
    gap: 14px;
    margin-bottom: 16px;
    padding: 16px;
    border: 1px solid #2a3847;
    border-radius: 10px;
    background: rgba(255, 255, 255, .018);
}

.cash-toolbar h3 {
    margin: 0;
    color: var(--ink);
    font-size: 18px;
    line-height: 1.2;
}

.cash-toolbar .rp-btn {
    justify-self: start;
}

.cash-admin-shell .rp-form-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(170px, 1fr));
    gap: 12px;
}

.cash-admin-shell .rp-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.cash-admin-shell .rp-check input {
    width: auto;
    min-height: 0;
}

.rp-profile-hero,
.rp-profile-overview {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
    gap: 16px;
    align-items: stretch;
    margin-bottom: 20px;
}

.rp-id-card {
    position: relative;
    min-width: 0;
    overflow: hidden;
    padding: 24px;
    border: 1px solid rgba(47, 191, 131, .46);
    border-radius: 12px;
    background:
        radial-gradient(circle at 12% 12%, rgba(47, 191, 131, .2), transparent 34%),
        linear-gradient(135deg, rgba(47, 191, 131, .16), rgba(106, 169, 255, .1)),
        var(--surface);
    box-shadow: 0 22px 70px rgba(0, 0, 0, .34);
}

.rp-id-card-featured {
    min-height: 360px;
}

.rp-id-card-bg-text {
    position: absolute;
    right: -18px;
    bottom: 2px;
    color: rgba(255, 255, 255, .035);
    font-size: 88px;
    font-weight: 900;
    line-height: 1;
    pointer-events: none;
}

.rp-id-card-top,
.rp-id-card-body,
.rp-id-card-statuses {
    display: flex;
    gap: 14px;
}

.rp-id-card-top {
    position: relative;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 22px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.rp-id-card-body {
    position: relative;
    align-items: stretch;
}

.rp-id-photo {
    display: grid;
    grid-template-rows: 1fr auto;
    flex: 0 0 112px;
    width: 112px;
    min-height: 152px;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 8px;
    background: #0b1118;
    color: var(--accent-2);
    font-size: 48px;
    font-weight: 900;
}

.rp-id-photo span {
    display: block;
    align-self: end;
    line-height: 1;
}

.rp-id-photo small {
    align-self: end;
    justify-self: center;
    margin-bottom: 12px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    line-height: 1;
}

.rp-id-card h2,
.rp-id-card p,
.rp-id-card dl {
    margin: 0;
}

.rp-id-card h2 {
    margin: 4px 0 14px;
    color: var(--ink);
    font-size: 34px;
    line-height: 1.08;
}

.rp-id-card p {
    color: var(--muted);
    font-weight: 800;
}

.rp-id-card dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(140px, 1fr));
    gap: 12px 18px;
}

.rp-id-card dt {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.rp-id-card dd {
    margin: 0;
    color: var(--ink);
    font-weight: 800;
    overflow-wrap: anywhere;
}

.rp-id-code {
    display: grid;
    flex: 0 0 124px;
    grid-template-columns: repeat(4, 1fr);
    gap: 5px;
    align-content: start;
    margin-left: auto;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #f4f7f5;
}

.rp-id-code span {
    aspect-ratio: 1;
    background: #08110d;
}

.rp-id-code span:nth-child(2),
.rp-id-code span:nth-child(5),
.rp-id-code span:nth-child(7) {
    opacity: .22;
}

.rp-id-code small {
    grid-column: 1 / -1;
    color: #08110d;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0;
    text-align: center;
}

.rp-id-card-statuses {
    position: relative;
    flex-wrap: wrap;
    margin-top: 22px;
}

.rp-id-card-statuses span {
    padding: 6px 9px;
    border: 1px solid rgba(47, 191, 131, .24);
    border-radius: 999px;
    background: rgba(47, 191, 131, .08);
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 800;
}

.rp-card-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.rp-card-head h2,
.rp-card-head p {
    margin: 0;
}

.rp-timeline {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.rp-timeline a {
    display: grid;
    gap: 3px;
    padding: 10px 0 10px 12px;
    border-left: 3px solid rgba(47, 191, 131, .42);
    color: inherit;
    text-decoration: none;
}

.rp-timeline strong {
    color: var(--accent-2);
    font-size: 11px;
    text-transform: uppercase;
}

.rp-timeline span {
    font-weight: 800;
}

.rp-timeline small {
    color: var(--muted);
}

.rp-achievement-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.rp-achievement {
    min-width: 0;
    min-height: 150px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.rp-achievement.unlocked {
    border-color: rgba(47, 191, 131, .45);
    background:
        linear-gradient(180deg, rgba(47, 191, 131, .12), transparent 78%),
        var(--surface);
}

.rp-achievement span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.rp-achievement.unlocked span {
    color: var(--accent-2);
}

.rp-achievement h3 {
    margin: 8px 0 6px;
    color: var(--ink);
    font-size: 16px;
}

.rp-achievement p,
.rp-achievement small {
    color: var(--muted);
}

.rp-achievement p {
    margin: 0;
}

.rp-achievement small {
    display: block;
    margin-top: 8px;
    font-weight: 800;
}

.rp-stat-value {
    margin: 4px 0 6px;
    color: var(--ink);
    font-size: 34px;
    font-weight: 900;
    line-height: 1;
}

@media (max-width: 1320px) {
    .cash-kpi-grid {
        grid-template-columns: repeat(3, minmax(180px, 1fr));
    }

    .rp-achievement-grid {
        grid-template-columns: repeat(3, minmax(180px, 1fr));
    }
}

@media (max-width: 980px) {
    .cash-admin-shell .rp-form-grid {
        grid-template-columns: repeat(2, minmax(170px, 1fr));
    }

    .rp-profile-hero,
    .rp-profile-overview {
        grid-template-columns: 1fr;
    }

    .rp-id-card-body {
        flex-wrap: wrap;
    }

    .rp-id-code {
        margin-left: 0;
    }

    .rp-achievement-grid {
        grid-template-columns: repeat(2, minmax(180px, 1fr));
    }
}

@media (max-width: 720px) {
    .cash-kpi-grid,
    .cash-admin-shell .rp-form-grid {
        grid-template-columns: 1fr;
    }

    .cash-toolbar .rp-btn {
        width: 100%;
    }

    .rp-id-card dl,
    .rp-achievement-grid {
        grid-template-columns: 1fr;
    }

    .rp-id-photo {
        flex-basis: 92px;
        width: 92px;
        min-height: 112px;
    }
}
/* Mobile operators */
.mobile-head {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.mobile-operator-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
    margin: 22px 0;
}

.mobile-card,
.mobile-hero {
    border-radius: 8px;
    padding: 22px;
    color: #fff;
    overflow: hidden;
    position: relative;
}

.mobile-card h2,
.mobile-hero h1 {
    margin-top: 0;
}

.mobile-aurora {
    background: linear-gradient(135deg, #12324a, #1b6ca8 58%, #d7edf7);
}

.mobile-neonova {
    background: linear-gradient(135deg, #2a132a, #d61f69 58%, #ffd166);
}

.mobile-taiga {
    background: linear-gradient(135deg, #173527, #2f6f4e 58%, #b7d8a6);
}

.mobile-card .rp-eyebrow,
.mobile-hero .rp-eyebrow,
.mobile-card .rp-lead,
.mobile-hero .rp-lead {
    color: rgba(255, 255, 255, 0.82);
}

.mobile-card .rp-btn {
    background: rgba(255, 255, 255, 0.94);
    color: #111827;
}

.mobile-offer-strip {
    display: grid;
    gap: 8px;
    margin: 18px 0;
}

.mobile-offer-strip span {
    padding: 8px 10px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.14);
}

.mobile-hero {
    min-height: 260px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
    align-items: end;
    gap: 24px;
    margin-bottom: 22px;
}

.mobile-hero-meter {
    padding: 18px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.16);
}

.mobile-hero-meter span,
.mobile-hero-meter small {
    display: block;
    color: rgba(255, 255, 255, 0.8);
}

.mobile-hero-meter strong {
    display: block;
    font-size: 36px;
    line-height: 1.1;
    margin: 8px 0;
}

.mobile-tariff-card {
    min-height: 360px;
}

.rp-inline-form {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: end;
}

@media (max-width: 720px) {
    .mobile-hero {
        grid-template-columns: 1fr;
        min-height: 320px;
    }
}
