:root {
    --abc-ink: #2b1717;
    --abc-ink-rgb: 43, 23, 23;
    --abc-ink-soft: #725454;
    --abc-primary: #630606;
    --abc-primary-rgb: 99, 6, 6;
    --abc-primary-deep: #470404;
    --abc-primary-strong: #8a1a1a;
    --abc-accent: #c68d2b;
    --abc-accent-soft: #f0dfbc;
    --abc-surface: rgba(255, 255, 255, 0.92);
    --abc-surface-strong: #ffffff;
    --abc-border: rgba(99, 6, 6, 0.12);
    --abc-success: #2d6a4f;
    --abc-danger: #9f2f34;
    --abc-warning: #9a6c16;
    --abc-info: #7b2a2a;
    --abc-shadow: 0 24px 60px rgba(71, 4, 4, 0.16);
    --abc-radius-xl: 28px;
    --abc-radius-lg: 22px;
    --abc-radius-md: 16px;
    --bs-primary: var(--abc-primary);
    --bs-primary-rgb: var(--abc-primary-rgb);
    --bs-link-color: var(--abc-primary);
    --bs-link-hover-color: var(--abc-primary-deep);
    --bs-focus-ring-color: rgba(var(--abc-primary-rgb), 0.2);
}

.select2-container {
    width: 100% !important;
}

.select2-container--default .select2-selection--multiple {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    min-height: calc(3.5rem + 2px);
    padding: 0.55rem 0.8rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.14);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.select2-container--default .select2-selection--single {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    height: auto;
    min-height: calc(3.5rem + 2px);
    padding: 0.55rem 3rem 0.55rem 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.14);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.select2-container--default.select2-container--focus .select2-selection--multiple {
    border-color: rgba(var(--abc-primary-rgb), 0.4);
    box-shadow: 0 0 0 0.28rem rgba(var(--abc-primary-rgb), 0.12);
}

.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: rgba(var(--abc-primary-rgb), 0.4);
    box-shadow: 0 0 0 0.28rem rgba(var(--abc-primary-rgb), 0.12);
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    width: 100%;
    padding: 0;
    color: var(--abc-ink);
    line-height: 1.45;
    white-space: normal;
    overflow: visible;
    text-overflow: initial;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: rgba(var(--abc-primary-rgb), 0.6);
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    position: absolute;
    top: 50%;
    right: 0.95rem;
    width: 1rem;
    height: 1rem;
    transform: translateY(-50%);
}

.select2-container--default .select2-selection--single .select2-selection__clear {
    position: absolute;
    top: 50%;
    right: 2.15rem;
    margin: 0;
    color: var(--abc-ink-soft);
    transform: translateY(-50%);
}

.select2-container--default .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0;
    margin: 0;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0;
    padding: 0.35rem 0.7rem;
    border: 0;
    border-radius: 999px;
    background: rgba(var(--abc-primary-rgb), 0.1);
    color: var(--abc-primary-deep);
    font-size: 0.92rem;
    font-weight: 600;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    margin-right: 0.1rem;
    color: inherit;
}

.select2-container--default .select2-search--inline .select2-search__field {
    min-height: 1.5rem;
    margin: 0;
    color: var(--abc-ink);
    font-size: 1rem;
}

.select2-container--default .select2-search--inline .select2-search__field::placeholder {
    color: rgba(var(--abc-primary-rgb), 0.55);
}

.select2-dropdown {
    overflow: hidden;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.14);
    border-radius: 18px;
    box-shadow: 0 24px 46px rgba(71, 4, 4, 0.14);
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background: rgba(var(--abc-primary-rgb), 0.08);
    color: var(--abc-primary-deep);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    color: var(--abc-ink);
    background: #f6efee;
    font-family: 'Public Sans', 'Segoe UI', sans-serif;
}

h1,
h2,
h3,
h4 {
    font-family: 'Fraunces', Georgia, serif;
    letter-spacing: -0.03em;
}

a {
    color: inherit;
}

.eyebrow {
    display: inline-flex;
    margin-bottom: 0.75rem;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--abc-accent);
}

.public-shell {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(198, 141, 43, 0.18), transparent 34%),
        radial-gradient(circle at right, rgba(99, 6, 6, 0.16), transparent 28%),
        linear-gradient(135deg, #3f0f0f 0%, #630606 46%, #f5ece4 46%, #f6efee 100%);
}

.public-shell__gradient,
.public-shell__mesh {
    position: fixed;
    inset: 0;
    pointer-events: none;
}

.public-shell__mesh {
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.55), transparent 80%);
}

.public-shell__content {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem;
}

.public-shell__flash {
    position: fixed;
    top: 1.5rem;
    left: 50%;
    z-index: 3;
    width: min(1180px, calc(100% - 2rem));
    transform: translateX(-50%);
    pointer-events: none;
}

.login-shell {
    display: grid;
    grid-template-columns: minmax(280px, 1.1fr) minmax(320px, 430px);
    gap: 2rem;
    width: min(1180px, 100%);
    align-items: stretch;
}

.login-shell__brand,
.login-card,
.surface-card,
.hero-card {
    border: 1px solid var(--abc-border);
    border-radius: var(--abc-radius-xl);
    box-shadow: var(--abc-shadow);
    backdrop-filter: blur(18px);
}

.login-shell__brand {
    padding: 3rem;
    color: #f8fbff;
    background:
        radial-gradient(circle at top left, rgba(198, 141, 43, 0.2), transparent 28%),
        linear-gradient(155deg, rgba(71, 4, 4, 0.94), rgba(99, 6, 6, 0.82));
}

.brand-lockup {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.brand-lockup__mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 112px;
    height: 112px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.brand-lockup h1 {
    margin: 0;
    font-size: clamp(3rem, 8vw, 5rem);
}

.login-shell__lead {
    max-width: 34rem;
    margin-bottom: 2rem;
    color: rgba(248, 251, 255, 0.8);
    font-size: 1.05rem;
    line-height: 1.75;
}

.login-shell__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.feature-chip {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--abc-radius-md);
    background: rgba(255, 255, 255, 0.06);
}

.feature-chip strong,
.feature-chip span {
    display: block;
}

.feature-chip span {
    margin-top: 0.35rem;
    color: rgba(248, 251, 255, 0.76);
}

.feature-chip--highlight {
    background: linear-gradient(135deg, rgba(198, 141, 43, 0.18), rgba(255, 255, 255, 0.08));
}

.login-card {
    display: flex;
    flex-direction: column;
    gap: 1.35rem;
    padding: 2rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.92));
}

.login-card__header h2 {
    margin-bottom: 0.5rem;
}

.login-card__header p {
    margin-bottom: 1.5rem;
    color: var(--abc-ink-soft);
}

.login-card .form-label {
    font-weight: 600;
}

.login-card__meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.03);
}

.login-card__meta-label {
    display: inline-flex;
    margin-bottom: 0.2rem;
    color: var(--abc-ink-soft);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.login-card .form-control,
.filter-bar .form-control,
.management-card .form-control,
.management-card .form-select {
    border: 1px solid rgba(var(--abc-ink-rgb), 0.16);
    border-radius: 14px;
    min-height: 3.2rem;
    background: rgba(255, 255, 255, 0.96);
}

.form-control:focus,
.form-select:focus,
.btn:focus-visible {
    border-color: rgba(var(--abc-primary-rgb), 0.35);
    box-shadow: 0 0 0 0.25rem rgba(var(--abc-primary-rgb), 0.12);
}

.btn {
    border-radius: 999px;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.btn-primary {
    border-color: var(--abc-primary);
    background: linear-gradient(135deg, var(--abc-primary), var(--abc-primary-strong));
}

.btn-primary:hover,
.btn-primary:focus {
    border-color: var(--abc-primary-deep);
    background: linear-gradient(135deg, var(--abc-primary-deep), #630606);
}

.flash-stack {
    width: min(100%, 1180px);
    margin: 0 auto 1rem;
}

.flash-stack__alert {
    border: 0;
    border-radius: 16px;
    box-shadow: 0 18px 42px rgba(43, 23, 23, 0.14);
    pointer-events: auto;
}

.login-card__support {
    padding: 1rem 1.1rem;
    border-radius: var(--abc-radius-md);
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    background: rgba(255, 255, 255, 0.78);
}

.login-card__support p {
    margin: 0.3rem 0 0;
    color: var(--abc-ink-soft);
}

.login-card__demo {
    padding: 1rem 1.1rem;
    border-radius: var(--abc-radius-md);
    background: #f4f2ec;
}

.login-card__demo ul {
    margin: 0.75rem 0 0;
    padding-left: 1rem;
}

.consent-card {
    width: min(560px, 100%);
    padding: 2.4rem;
    border: 1px solid var(--abc-border);
    border-radius: var(--abc-radius-xl);
    box-shadow: var(--abc-shadow);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.92));
    backdrop-filter: blur(18px);
}

.consent-card__brand {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.consent-card__brand strong {
    display: block;
    margin-top: 0.15rem;
    font-size: 1.15rem;
    color: var(--abc-ink);
}

.consent-card__brand-mark {
    display: grid;
    place-items: center;
    width: 72px;
    height: 72px;
    border-radius: 22px;
    background: linear-gradient(145deg, rgba(22, 50, 79, 0.1), rgba(198, 141, 43, 0.18));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.consent-card__brand-mark img {
    width: 52px;
    height: 52px;
}

.consent-card--success {
    border-color: rgba(32, 110, 69, 0.22);
}

.consent-card--warning {
    border-color: rgba(180, 113, 0, 0.22);
}

.consent-card--danger {
    border-color: rgba(160, 46, 46, 0.24);
}

.consent-card__header h1 {
    margin-bottom: 0.85rem;
}

.consent-card__header p {
    margin-bottom: 0;
    color: var(--abc-ink-soft);
    line-height: 1.7;
}

.consent-card__meta {
    display: grid;
    gap: 0.9rem;
    margin: 1.6rem 0 0;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.03);
}

.consent-card__meta div {
    display: grid;
    gap: 0.2rem;
}

.consent-card__meta dt {
    color: var(--abc-ink-soft);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.consent-card__meta dd {
    margin: 0;
    font-weight: 600;
}

.admin-shell {
    background:
        radial-gradient(circle at top left, rgba(198, 141, 43, 0.14), transparent 30%),
        linear-gradient(180deg, #f2e7e6 0%, #faf7f6 100%);
}

.admin-shell__bg {
    position: fixed;
    inset: 0;
    background-image: linear-gradient(rgba(var(--abc-primary-rgb), 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(var(--abc-primary-rgb), 0.03) 1px, transparent 1px);
    background-size: 34px 34px;
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.9), transparent 92%);
    pointer-events: none;
}

.admin-shell__layout {
    position: relative;
    display: grid;
    grid-template-columns: 290px minmax(0, 1fr);
    min-height: 100vh;
    transition: grid-template-columns 0.24s ease;
}

.sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding: 2rem 1.35rem;
    color: #f2f7fb;
    background: linear-gradient(180deg, #3d0f0f, #630606 72%, #8a1a1a);
}

.sidebar__brand {
    display: flex;
    gap: 1rem;
    align-items: center;
}

.sidebar__brand-copy {
    min-width: 0;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.sidebar__brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.1);
}

.sidebar__brand h1 {
    margin: 0;
    font-size: 1.9rem;
}

.sidebar__eyebrow,
.topbar__eyebrow {
    margin: 0 0 0.2rem;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.76rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sidebar__nav {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.sidebar__group {
    display: grid;
    gap: 0.55rem;
}

.sidebar__group + .sidebar__group {
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar__group-label {
    margin: 0 !important;
    padding: 0 0.35rem;
    color: rgba(255, 255, 255, 0.56);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sidebar__group-links {
    display: grid;
    gap: 0.55rem;
}

.sidebar__link {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.95rem 1rem;
    border: 1px solid transparent;
    border-radius: 18px;
    color: rgba(242, 247, 251, 0.82);
    text-decoration: none;
    transition: all 0.2s ease;
}

.sidebar__link-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    flex: 0 0 1.25rem;
}

.sidebar__link-icon svg {
    width: 1.25rem;
    height: 1.25rem;
}

.sidebar__link-label {
    white-space: nowrap;
}

.sidebar__link:hover,
.sidebar__link.is-active {
    border-color: rgba(255, 255, 255, 0.12);
    color: #ffffff;
    background: rgba(255, 255, 255, 0.1);
}

.sidebar__panel {
    padding: 1.1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.09);
}

.sidebar__panel:first-of-type {
    margin-top: auto;
}

.sidebar__panel--muted {
    background: rgba(255, 255, 255, 0.05);
}

.panel__label {
    display: inline-flex;
    margin-bottom: 0.55rem;
    color: var(--abc-accent-soft);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sidebar__panel p {
    margin: 0;
    color: rgba(242, 247, 251, 0.76);
}

.admin-shell__main {
    display: flex;
    flex-direction: column;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.7rem 2rem 1.2rem;
}

.topbar__title {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.topbar h2 {
    margin: 0;
    font-size: 2rem;
}

.topbar__sidebar-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--abc-primary);
    border-color: rgba(var(--abc-primary-rgb), 0.18);
    background: rgba(255, 255, 255, 0.86);
}

.topbar__sidebar-toggle-icon {
    display: inline-flex;
    width: 1rem;
    height: 1rem;
}

.topbar__sidebar-toggle-icon svg {
    width: 1rem;
    height: 1rem;
}

.topbar__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: end;
    gap: 1rem;
}

.topbar__status {
    display: flex;
    flex-wrap: wrap;
    justify-content: end;
    gap: 0.55rem;
}

.topbar__user {
    display: grid;
    justify-items: end;
    gap: 0.1rem;
}

.topbar__user span {
    color: var(--abc-ink-soft);
    font-size: 0.95rem;
}

.topbar__logout {
    color: var(--abc-primary);
    border-color: rgba(var(--abc-primary-rgb), 0.18);
    background: rgba(255, 255, 255, 0.85);
}

.topbar__impersonation-stop {
    white-space: nowrap;
}

.admin-shell--sidebar-collapsed .admin-shell__layout {
    grid-template-columns: 108px minmax(0, 1fr);
}

.admin-shell--sidebar-collapsed .sidebar {
    padding-left: 0.9rem;
    padding-right: 0.9rem;
}

.admin-shell--sidebar-collapsed .sidebar__brand {
    justify-content: center;
}

.admin-shell--sidebar-collapsed .sidebar__brand-copy,
.admin-shell--sidebar-collapsed .sidebar__group-label,
.admin-shell--sidebar-collapsed .sidebar__panel,
.admin-shell--sidebar-collapsed .topbar__sidebar-toggle-label {
    opacity: 0;
    width: 0;
    overflow: hidden;
    transform: translateX(-8px);
    pointer-events: none;
}

.admin-shell--sidebar-collapsed .sidebar__nav {
    justify-items: center;
    gap: 0.6rem;
}

.admin-shell--sidebar-collapsed .sidebar__group {
    gap: 0.35rem;
}

.admin-shell--sidebar-collapsed .sidebar__group-label {
    display: none !important;
}

.admin-shell--sidebar-collapsed .sidebar__group + .sidebar__group {
    padding-top: 0;
    border-top: 0;
}

.admin-shell--sidebar-collapsed .sidebar__link {
    justify-content: center;
    width: 100%;
    padding-left: 0.8rem;
    padding-right: 0.8rem;
}

.admin-shell--sidebar-collapsed .sidebar__link-label {
    display: none;
}

.admin-shell--sidebar-collapsed .sidebar__panel:first-of-type {
    margin-top: 0;
}

.page-shell {
    padding: 0 2rem 2rem;
}

.page-shell--banner-only {
    padding-bottom: 0;
}

.surface-card,
.hero-card {
    padding: 1.5rem;
    background: var(--abc-surface);
}

.hero-card {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    background:
        linear-gradient(120deg, rgba(99, 6, 6, 0.96), rgba(138, 26, 26, 0.92)),
        radial-gradient(circle at top left, rgba(198, 141, 43, 0.3), transparent 25%);
    color: #f5f9fc;
}

.hero-card h3 {
    margin-bottom: 0.75rem;
    font-size: 2rem;
}

.hero-card p {
    max-width: 42rem;
    margin-bottom: 0;
    color: rgba(245, 249, 252, 0.8);
}

.hero-card--dashboard {
    margin-bottom: 1.5rem;
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.2), transparent 26%),
        radial-gradient(circle at left 18%, rgba(255, 255, 255, 0.08), transparent 24%),
        linear-gradient(132deg, #2f1918 0%, #4c2321 42%, #6d3e26 100%);
}

.hero-card--profile {
    align-items: stretch;
}

.hero-card__content {
    flex: 1 1 auto;
    min-width: 0;
}

.hero-card__aside {
    display: grid;
    flex: 0 1 290px;
    align-content: start;
    gap: 0.85rem;
    width: min(490px, 100%);
    min-width: 0;
    padding: 0.75rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.12);
}

.hero-card__aside-label {
    color: rgba(245, 249, 252, 0.7);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.hero-card__aside-stack {
    display: grid;
    gap: 0.25rem;
}

.hero-card__aside-stack span {
    color: rgba(245, 249, 252, 0.76);
}

.dashboard-hero__meta {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1.25rem;
}

.dashboard-hero__meta .status-pill {
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.1);
    color: #f8f0e6;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.dashboard-hero__meta .status-pill--info {
    background: rgba(198, 141, 43, 0.18);
    color: #f7e4bc;
}

.dashboard-hero__meta .status-pill--muted {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(248, 240, 230, 0.9);
}

.dashboard-hero__focus {
    display: grid;
    gap: 0.25rem;
    margin-top: 1rem;
    color: rgba(245, 249, 252, 0.82);
    font-size: 0.95rem;
}

.dashboard-hero__focus strong {
    color: #fff4e3;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-hero__focus span {
    color: rgba(245, 249, 252, 0.72);
}

.dashboard-brief__list {
    display: grid;
    gap: 0.85rem;
}

.dashboard-brief__item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 0.85rem 0.95rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.dashboard-brief__item span {
    color: rgba(245, 249, 252, 0.72);
    font-size: 0.92rem;
}

.dashboard-brief__item strong {
    font-size: 1.2rem;
}

.hero-card--profile .dashboard-brief__item {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.4rem;
}

.hero-card--profile .dashboard-brief__item strong {
    max-width: 100%;
    text-align: left;
    overflow-wrap: anywhere;
    font-size: 1.02rem;
}

.hero-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.5rem;
}

.hero-action {
    display: grid;
    gap: 0.3rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.07);
    color: #f5f9fc;
    text-decoration: none;
}

.hero-action span {
    color: rgba(245, 249, 252, 0.76);
    font-size: 0.92rem;
}

.dashboard-section {
    margin-bottom: 1.5rem;
}

.dashboard-kpi-grid,
.dashboard-action-grid {
    display: grid;
    gap: 1rem;
}

.dashboard-action-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.dashboard-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dashboard-action-card {
    display: grid;
    gap: 0.55rem;
    padding: 1.25rem;
    border: 1px solid var(--abc-border);
    border-radius: 24px;
    text-decoration: none;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(252, 247, 247, 0.92));
    box-shadow: var(--abc-shadow);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.dashboard-action-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 28px 64px rgba(71, 4, 4, 0.14);
}

.dashboard-action-card__label {
    color: var(--abc-ink-soft);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-action-card__value {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 2rem;
    line-height: 1;
}

.dashboard-action-card p {
    margin: 0;
    color: var(--abc-ink-soft);
}

.dashboard-action-card--primary {
    border-color: rgba(var(--abc-primary-rgb), 0.18);
}

.dashboard-action-card--primary .dashboard-action-card__value {
    color: var(--abc-primary);
}

.dashboard-action-card--accent {
    border-color: rgba(198, 141, 43, 0.26);
}

.dashboard-action-card--accent .dashboard-action-card__value {
    color: var(--abc-warning);
}

.dashboard-action-card--info {
    border-color: rgba(var(--abc-primary-rgb), 0.14);
    background: linear-gradient(180deg, rgba(248, 240, 240, 0.95), rgba(255, 255, 255, 0.92));
}

.dashboard-action-card--info .dashboard-action-card__value {
    color: var(--abc-info);
}

.dashboard-action-card--success {
    border-color: rgba(45, 106, 79, 0.2);
}

.dashboard-action-card--success .dashboard-action-card__value {
    color: var(--abc-success);
}

.dashboard-action-card--warning {
    border-color: rgba(154, 108, 22, 0.24);
    background: linear-gradient(180deg, rgba(255, 249, 238, 0.96), rgba(255, 255, 255, 0.92));
}

.dashboard-action-card--warning .dashboard-action-card__value {
    color: var(--abc-warning);
}

.dashboard-action-card--danger {
    border-color: rgba(159, 47, 52, 0.24);
    background: linear-gradient(180deg, rgba(255, 244, 244, 0.96), rgba(255, 255, 255, 0.92));
}

.dashboard-action-card--danger .dashboard-action-card__value {
    color: var(--abc-danger);
}

.dashboard-action-card--muted {
    box-shadow: 0 20px 48px rgba(71, 4, 4, 0.08);
}

.dashboard-action-card--muted .dashboard-action-card__value {
    color: var(--abc-ink);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.workspace-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.workspace-card {
    position: relative;
    overflow: hidden;
    padding: 1.3rem;
    border: 1px solid var(--abc-border);
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(252, 247, 247, 0.9));
    box-shadow: var(--abc-shadow);
}

.workspace-card::after {
    content: '';
    position: absolute;
    inset: auto -40px -40px auto;
    width: 130px;
    height: 130px;
    border-radius: 50%;
    opacity: 0.14;
}

.workspace-card--primary::after {
    background: var(--abc-primary);
}

.workspace-card--accent::after {
    background: var(--abc-accent);
}

.workspace-card--success::after {
    background: var(--abc-success);
}

.workspace-card__kicker {
    display: inline-flex;
    margin-bottom: 0.75rem;
    color: var(--abc-ink-soft);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.workspace-card h3 {
    margin-bottom: 0.55rem;
}

.workspace-card p {
    max-width: 26rem;
    margin-bottom: 0;
    color: var(--abc-ink-soft);
}

.surface-card--accent {
    background: linear-gradient(180deg, rgba(240, 223, 188, 0.44), rgba(255, 255, 255, 0.9));
}

.surface-card--subtle {
    padding: 1.1rem 1.2rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    background: linear-gradient(180deg, rgba(99, 6, 6, 0.03), rgba(255, 255, 255, 0.88));
    box-shadow: none;
}

.workspace-intro__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.management-card {
    height: 100%;
}

.workspace-intro__lead {
    color: var(--abc-ink-soft);
}

.management-card__lead,
.role-card p {
    color: var(--abc-ink-soft);
}

.management-textarea {
    min-height: 8rem;
    resize: vertical;
}

.management-textarea--lg {
    min-height: 12rem;
}

.management-textarea--xl {
    min-height: 18rem;
    font-family: "SFMono-Regular", "Menlo", "Consolas", monospace;
    font-size: 0.95rem;
    line-height: 1.55;
}

.stat-card__label {
    display: inline-flex;
    margin-bottom: 0.9rem;
    color: var(--abc-ink-soft);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
}

.stat-card__value {
    display: block;
    margin-bottom: 0.4rem;
    font-size: 2.35rem;
    line-height: 1;
}

.stat-card p {
    margin: 0;
    color: var(--abc-ink-soft);
}

.section-heading {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    margin-bottom: 1.25rem;
}

.section-heading h3 {
    margin: 0;
}

.dashboard-empty {
    padding: 1rem 1.1rem;
    border: 1px dashed rgba(var(--abc-primary-rgb), 0.18);
    border-radius: 18px;
    color: var(--abc-ink-soft);
    background: rgba(255, 255, 255, 0.56);
}

.dashboard-campaign-cell {
    display: grid;
    gap: 0.2rem;
}

.dashboard-campaign-meta {
    display: grid;
    gap: 0.15rem;
}

.dashboard-campaign-meta span {
    color: var(--abc-ink-soft);
    font-size: 0.84rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dashboard-task-list {
    display: grid;
    gap: 0.9rem;
}

.dashboard-task {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(252, 247, 247, 0.9));
}

.dashboard-task__content {
    display: grid;
    gap: 0.3rem;
}

.dashboard-task__content p {
    margin: 0;
    color: var(--abc-ink-soft);
}

.dashboard-task--danger {
    border-left: 4px solid var(--abc-danger);
}

.dashboard-task--warning {
    border-left: 4px solid var(--abc-warning);
}

.dashboard-task--info {
    border-left: 4px solid var(--abc-info);
}

.dashboard-task--success {
    border-left: 4px solid var(--abc-success);
}

.app-table {
    margin: 0;
    --bs-table-bg: transparent;
    --bs-table-border-color: rgba(var(--abc-primary-rgb), 0.09);
}

.app-table thead th {
    padding-top: 0;
    color: var(--abc-ink-soft);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.app-table tbody td {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.app-table tbody tr.is-selected {
    --bs-table-bg: rgba(var(--abc-primary-rgb), 0.05);
}

.contacts-list-table {
    min-width: 980px;
}

.contacts-list-table tbody td {
    vertical-align: top;
}

.table-select {
    width: 3.2rem;
    text-align: center;
}

.token-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.token,
.status-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.36rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.token {
    background: rgba(var(--abc-primary-rgb), 0.08);
    color: var(--abc-primary);
}

.token-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(var(--abc-primary-rgb), 0.08);
    color: var(--abc-primary);
    font-size: 0.83rem;
    font-weight: 700;
}

.token-pill--muted {
    background: rgba(75, 97, 119, 0.12);
    color: var(--abc-ink-soft);
}

.status-pill--success {
    background: rgba(45, 106, 79, 0.12);
    color: var(--abc-success);
}

.status-pill--danger {
    background: rgba(159, 47, 52, 0.12);
    color: var(--abc-danger);
}

.status-pill--warning {
    background: rgba(154, 108, 22, 0.14);
    color: var(--abc-warning);
}

.status-pill--info {
    background: rgba(123, 42, 42, 0.12);
    color: var(--abc-info);
}

.status-pill--muted {
    background: rgba(75, 97, 119, 0.12);
    color: var(--abc-ink-soft);
}

.scope-list,
.check-list,
.roadmap-list {
    display: grid;
    gap: 0.85rem;
}

.scope-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
}

.scope-item p {
    margin: 0.25rem 0 0;
    color: var(--abc-ink-soft);
}

.scope-item__meta {
    display: grid;
    justify-items: end;
    color: var(--abc-ink-soft);
    font-size: 0.9rem;
}

.check-list,
.roadmap-list {
    margin: 0;
    padding-left: 1.1rem;
}

.check-list li,
.roadmap-list li {
    padding-left: 0.2rem;
}

.filter-bar {
    display: flex;
    gap: 1rem;
    align-items: end;
    margin-bottom: 1.5rem;
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.03);
}

.filter-bar__field {
    flex: 1 1 320px;
}

.filter-bar__checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 3rem;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.78);
    color: var(--abc-ink);
    font-weight: 600;
}

.filter-bar__checkbox span {
    line-height: 1.3;
}

.filter-bar__actions {
    display: flex;
    gap: 0.75rem;
}

.workspace-intro__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1rem;
}

.empty-state {
    display: grid;
    gap: 0.35rem;
    justify-items: center;
    padding: 1.6rem;
    text-align: center;
}

.empty-state p {
    margin-bottom: 0;
    color: var(--abc-ink-soft);
}

.empty-state--standalone {
    max-width: 560px;
    margin: 8vh auto;
}

.empty-state--drawer {
    padding: 0;
    justify-items: start;
    text-align: left;
}

.selection-panel {
    display: grid;
    gap: 0.75rem;
}

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

.selection-panel--dense {
    max-height: 360px;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.selection-chip {
    display: flex;
    gap: 0.85rem;
    align-items: start;
    min-height: 100%;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.1);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.selection-chip:hover {
    border-color: rgba(var(--abc-primary-rgb), 0.18);
    box-shadow: 0 16px 28px rgba(34, 16, 16, 0.07);
    transform: translateY(-1px);
}

.selection-chip--dense {
    padding: 0.8rem 0.9rem;
}

.selection-chip input {
    margin-top: 0.25rem;
    flex: 0 0 auto;
}

.selection-chip span {
    display: grid;
    gap: 0.2rem;
}

.selection-chip--static {
    cursor: default;
}

.selection-chip small {
    color: var(--abc-ink-soft);
    line-height: 1.4;
}

.field-hint {
    margin-top: 0.45rem;
    color: var(--abc-ink-soft);
    font-size: 0.9rem;
    line-height: 1.45;
}

.form-section {
    display: grid;
    gap: 1.1rem;
    height: 100%;
    padding: 1.2rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.74);
    box-shadow: 0 20px 50px rgba(25, 12, 12, 0.05);
}

.form-section__header {
    display: grid;
    gap: 0.35rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.form-section__header h5 {
    margin: 0;
    font-size: 1.1rem;
}

.form-section__header p {
    margin: 0;
    color: var(--abc-ink-soft);
    line-height: 1.55;
}

.form-section__body {
    align-content: start;
}

.form-subsection-grid {
    display: grid;
    gap: 1rem;
}

.form-subsection {
    display: grid;
    gap: 0.95rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.84);
}

.form-subsection__header {
    display: grid;
    gap: 0.2rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.form-subsection__header h6 {
    margin: 0;
    font-size: 1rem;
}

.bulk-field-grid {
    display: grid;
    gap: 0.9rem;
}

.bulk-field-row {
    display: grid;
    grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
}

.bulk-field-row__toggle {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.bulk-field-row--stacked {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
}

.bulk-field-row__body {
    display: grid;
    gap: 0.9rem;
}

.bulk-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.bulk-preview-card {
    display: grid;
    gap: 0.85rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.86);
}

.bulk-preview-list {
    display: grid;
    gap: 0.65rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.bulk-preview-list li {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.bulk-preview-list li span {
    color: var(--abc-ink-soft);
}

.bulk-preview-list--stacked li {
    align-items: start;
}

.import-source-card {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    align-items: center;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
}

.import-source-card p {
    margin: 0;
    color: var(--abc-ink-soft);
}

.import-mapping-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem 1rem;
}

.import-mapping-row {
    display: grid;
    gap: 0.45rem;
}

.import-mapping-row span {
    font-weight: 600;
}

.import-preview-stack {
    display: grid;
    gap: 1rem;
}

.management-actions,
.table-actions {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.table-actions {
    justify-content: end;
}

.table-actions__form {
    margin: 0;
}

.status-pill-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    align-items: center;
}

.modal-copy {
    margin-bottom: 1.25rem;
    color: rgba(34, 34, 34, 0.76);
}

.quick-status-target {
    padding: 1rem 1.125rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(var(--abc-primary-rgb), 0.06), rgba(var(--abc-primary-rgb), 0.02));
}

.quick-status-target strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 1rem;
}

.empty-inline-state {
    padding: 1rem 1.1rem;
    border: 1px dashed rgba(var(--abc-primary-rgb), 0.18);
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.03);
}

.empty-inline-state p {
    margin: 0.35rem 0 0;
    color: var(--abc-ink-soft);
}

.table-meta {
    display: grid;
    gap: 0.1rem;
}

.table-meta span {
    color: var(--abc-ink-soft);
    font-size: 0.92rem;
}

.contact-member-card {
    gap: 0.3rem;
}

.contact-member-meta {
    font-size: 0.84rem;
    color: var(--abc-ink-soft);
}

.user-contact-preview {
    display: grid;
    gap: 0.7rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(var(--abc-primary-rgb), 0.05), rgba(255, 255, 255, 0.88));
}

.user-contact-preview__header {
    display: grid;
    gap: 0.2rem;
}

.user-contact-preview__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.9rem;
    color: var(--abc-ink-soft);
    font-size: 0.92rem;
}

.user-contact-option {
    display: grid;
    gap: 0.25rem;
}

.user-contact-option__title {
    color: var(--abc-ink);
    font-size: 0.98rem;
}

.user-contact-option__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem 0.65rem;
    color: var(--abc-ink-soft);
    font-size: 0.86rem;
}

.contact-contribution-inline {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.2rem;
}

.contact-contribution-inline small {
    color: var(--abc-ink-soft);
    font-size: 0.82rem;
}

.table-muted {
    color: var(--abc-ink-soft);
    font-size: 0.92rem;
}

/* Verpaarung-Zelle */
.pairing-cell {
    display: grid;
    gap: 0.15rem;
}
.pairing-icon {
    display: inline-block;
    width: 1.1em;
    font-size: 0.78rem;
    opacity: 0.45;
}

/* Sortierbare Spaltenköpfe */
.app-table th[data-sortable] {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.app-table th[data-sortable]:hover {
    color: var(--abc-ink);
}
.sort-icon::after {
    content: '↕';
    font-size: 0.72rem;
    margin-left: 0.3em;
    opacity: 0.3;
}
.sort-asc .sort-icon::after {
    content: '↑';
    opacity: 0.75;
}
.sort-desc .sort-icon::after {
    content: '↓';
    opacity: 0.75;
}

.contacts-list-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 0 0 1rem;
    padding: 0.8rem 0.95rem;
    border-radius: 16px;
    background: rgba(var(--abc-primary-rgb), 0.04);
}

.contacts-list-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--abc-ink-soft);
    font-size: 0.84rem;
    font-weight: 600;
}

.contacts-list-meta {
    margin-bottom: 1rem;
}

.contacts-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(var(--abc-primary-rgb), 0.1);
}

.contacts-pagination__summary {
    color: var(--abc-ink-soft);
    font-size: 0.92rem;
}

.contacts-pagination .pagination {
    gap: 0.35rem;
}

.contacts-pagination .page-link {
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 12px;
    color: var(--abc-primary);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: none;
}

.contacts-pagination .page-item.active .page-link {
    border-color: rgba(var(--abc-primary-rgb), 0.95);
    background: rgb(var(--abc-primary-rgb));
    color: #fff;
}

.contacts-pagination .page-item.disabled .page-link {
    color: var(--abc-ink-soft);
    background: rgba(var(--abc-primary-rgb), 0.04);
}

.contact-member-scope {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--abc-ink-soft);
    font-size: 0.82rem;
    line-height: 1.3;
}

.contact-member-scope svg,
.contact-flag-icon svg {
    width: 0.95rem;
    height: 0.95rem;
    flex: 0 0 auto;
}

.contact-reachability {
    display: grid;
    gap: 0.22rem;
}

.contact-reachability__primary {
    color: var(--abc-ink);
    font-weight: 600;
    line-height: 1.35;
}

.contact-reachability__meta {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.3rem 0.7rem;
}

.contact-location,
.contact-tag-summary {
    display: inline-block;
    color: var(--abc-ink);
    font-size: 0.92rem;
    line-height: 1.4;
}

.contact-tag-summary {
    color: var(--abc-ink-soft);
}

.contact-newsletter-state {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.contact-status-overview {
    display: grid;
    gap: 0.35rem;
}

.contact-status-overview__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--abc-ink-soft);
    font-size: 0.84rem;
    line-height: 1.35;
}

.contact-status-overview__flag {
    margin-top: 0.05rem;
}

.contact-contribution-state {
    display: grid;
    gap: 0.32rem;
}

.contact-contribution-state__meta {
    color: var(--abc-ink-soft);
    font-size: 0.84rem;
    line-height: 1.4;
}

.contribution-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.contribution-quick-form {
    margin: 0;
}

.contribution-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 4.2rem;
    border-radius: 999px;
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.contribution-toggle:hover {
    transform: translateY(-1px);
}

.contribution-toggle.is-pending {
    opacity: 0.7;
    transform: none;
    cursor: wait;
}

.contribution-toggle--inactive {
    border: 1px solid rgba(var(--abc-primary-rgb), 0.16);
    background: rgba(255, 255, 255, 0.92);
    color: var(--abc-ink-soft);
}

.contribution-toggle--inactive:hover,
.contribution-toggle--inactive:focus {
    border-color: rgba(var(--abc-primary-rgb), 0.28);
    background: rgba(var(--abc-primary-rgb), 0.06);
    color: var(--abc-primary);
}

.contribution-toggle--active {
    border: 1px solid rgba(45, 106, 79, 0.18);
    background: linear-gradient(135deg, rgba(45, 106, 79, 0.96), rgba(57, 132, 97, 0.9));
    color: #f5fffa;
    box-shadow: 0 12px 22px rgba(45, 106, 79, 0.2);
}

.contribution-toggle--active:hover,
.contribution-toggle--active:focus {
    border-color: rgba(45, 106, 79, 0.24);
    background: linear-gradient(135deg, rgba(34, 90, 66, 0.98), rgba(45, 106, 79, 0.94));
    color: #ffffff;
}

.contact-flag-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.7rem;
    height: 1.7rem;
    border-radius: 999px;
    cursor: help;
}

.contact-flag-icon--warning {
    background: rgba(154, 108, 22, 0.14);
    color: var(--abc-warning);
}

.audit-log__impersonation {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.35rem;
}

.audit-log__context {
    display: block;
    max-width: 34rem;
    padding: 0.65rem 0.8rem;
    border-radius: 14px;
    background: rgba(99, 6, 6, 0.05);
    color: var(--abc-ink);
    font-size: 0.82rem;
    white-space: pre-wrap;
    word-break: break-word;
}

.impersonation-banner {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1.5rem;
    padding: 1rem 1.15rem;
    border: 1px solid rgba(198, 141, 43, 0.35);
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(198, 141, 43, 0.14), rgba(99, 6, 6, 0.06));
}

.impersonation-banner p {
    margin: 0.25rem 0 0;
    color: var(--abc-ink-soft);
}

.role-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.role-section__note {
    max-width: 44rem;
    margin: -0.35rem 0 1.25rem;
    color: var(--abc-ink-soft);
}

.role-list {
    display: grid;
    gap: 1rem;
}

.role-list-item {
    display: grid;
    gap: 1rem;
    padding: 1.15rem 1.2rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.07), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 243, 242, 0.9));
}

.role-list-item__main,
.role-list-item__footer {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.role-list-item__copy h4 {
    margin: 0.2rem 0 0.35rem;
}

.role-list-item__copy p {
    margin: 0;
    max-width: 42rem;
    color: var(--abc-ink-soft);
    line-height: 1.55;
}

.role-list-item__stats,
.role-list-item__groups,
.role-list-item__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.role-list-item__stats,
.role-list-item__actions {
    justify-content: end;
}

.role-list-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(var(--abc-primary-rgb), 0.08);
    color: var(--abc-primary-deep);
    font-size: 0.83rem;
    font-weight: 700;
}

.role-list-chip--muted {
    background: rgba(75, 97, 119, 0.12);
    color: var(--abc-ink-soft);
}

.role-list-item__system-note {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    color: var(--abc-ink-soft);
    font-size: 0.85rem;
    font-weight: 700;
}

.table-actions__hint {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    color: var(--abc-ink-soft);
    font-size: 0.83rem;
    font-weight: 700;
}

.role-card {
    display: grid;
    gap: 1rem;
    padding: 1.25rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 243, 242, 0.9));
}

.role-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.permission-group-stack {
    display: grid;
    gap: 1rem;
}

.permission-group-card {
    display: grid;
    gap: 0.9rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
}

.permission-group-card--compact {
    padding: 0.95rem 1rem;
}

.permission-group-card__header {
    display: grid;
    gap: 0.3rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.permission-group-card__header--split {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 0.8rem;
}

.permission-group-card__header h6 {
    margin: 0;
    font-size: 1rem;
}

.permission-group-card__header p {
    margin: 0;
    color: var(--abc-ink-soft);
    line-height: 1.45;
    font-size: 0.92rem;
}

.role-card__header h4 {
    margin: 0 0 0.35rem;
}

.role-card__header p {
    margin: 0;
    max-width: 34rem;
    color: var(--abc-ink-soft);
    line-height: 1.55;
}

.role-overview-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.role-overview-stat {
    display: grid;
    gap: 0.22rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.88);
}

.role-overview-stat span {
    color: var(--abc-ink-soft);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.role-overview-stat strong {
    color: var(--abc-primary-deep);
    font-size: 1.1rem;
}

.role-card__section-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: end;
}

.role-card__section-head h5 {
    margin: 0.2rem 0 0;
    font-size: 1rem;
}

.role-card__section-head--detail {
    padding-top: 0.2rem;
    border-top: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.role-group-overview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.role-group-overview-card {
    display: grid;
    gap: 0.55rem;
    padding: 1rem 1.05rem;
    text-align: left;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.09);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.84);
    color: inherit;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

.role-group-overview-card:hover,
.role-group-overview-card:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(var(--abc-primary-rgb), 0.2);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 16px 28px rgba(34, 16, 16, 0.08);
}

.role-group-overview-card:focus-visible {
    outline: 2px solid rgba(var(--abc-primary-rgb), 0.24);
    outline-offset: 2px;
}

.role-group-overview-card__topline {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    align-items: start;
}

.role-group-overview-card__topline strong {
    color: var(--abc-primary-deep);
    font-size: 0.96rem;
}

.role-group-overview-card p {
    margin: 0;
    color: var(--abc-ink-soft);
    font-size: 0.9rem;
    line-height: 1.5;
}

.permission-disclosure-stack {
    display: grid;
    gap: 0.75rem;
}

.permission-disclosure {
    overflow: hidden;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.permission-disclosure[open] {
    border-color: rgba(var(--abc-primary-rgb), 0.14);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(249, 242, 240, 0.9));
    box-shadow: 0 18px 30px rgba(34, 16, 16, 0.06);
}

.permission-disclosure__summary {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    padding: 1rem 1.05rem;
    cursor: pointer;
    list-style: none;
}

.permission-disclosure__summary::-webkit-details-marker {
    display: none;
}

.permission-disclosure__summary::marker {
    content: "";
}

.permission-disclosure__copy {
    display: grid;
    gap: 0.25rem;
}

.permission-disclosure__copy strong {
    font-size: 0.98rem;
}

.permission-disclosure__copy span {
    color: var(--abc-ink-soft);
    font-size: 0.9rem;
    line-height: 1.45;
}

.permission-disclosure__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    flex: 0 0 auto;
}

.permission-disclosure__chevron {
    width: 0.72rem;
    height: 0.72rem;
    border-right: 2px solid rgba(var(--abc-primary-rgb), 0.55);
    border-bottom: 2px solid rgba(var(--abc-primary-rgb), 0.55);
    transform: rotate(45deg);
    transition: transform 0.2s ease;
}

.permission-disclosure[open] .permission-disclosure__chevron {
    transform: rotate(225deg);
}

.permission-disclosure__body {
    padding: 0 1.05rem 1.05rem;
    border-top: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.permission-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    padding-top: 0.95rem;
}

.permission-list__item {
    display: grid;
    gap: 0.22rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.9);
}

.permission-list__item strong {
    font-size: 0.92rem;
    line-height: 1.4;
}

.permission-list__item small {
    color: var(--abc-ink-soft);
    font-family: "SFMono-Regular", "Menlo", "Consolas", monospace;
    font-size: 0.76rem;
    line-height: 1.4;
    word-break: break-word;
}

.role-card__empty-state {
    display: grid;
    gap: 0.7rem;
    padding: 1rem 1.05rem;
    border: 1px dashed rgba(var(--abc-primary-rgb), 0.18);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.7);
}

.role-card__empty-state p {
    margin: 0;
    color: var(--abc-ink-soft);
    line-height: 1.5;
}

.role-detail-stack {
    display: grid;
    gap: 1rem;
}

.role-detail-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.role-detail-stat {
    display: grid;
    gap: 0.2rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.84);
}

.role-detail-stat span {
    color: var(--abc-ink-soft);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.role-detail-stat strong {
    color: var(--abc-primary-deep);
    font-size: 1.05rem;
}

.role-detail-group-meta {
    display: flex;
    justify-content: flex-end;
    flex: 0 0 auto;
}

.offcanvas-panel {
    width: min(780px, 100vw);
    color: var(--abc-ink);
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.12), transparent 24%),
        linear-gradient(180deg, #fffefe 0%, #f7f2f1 100%);
}

.offcanvas-panel--wide {
    width: 40vw;
    min-width: 860px;
    max-width: 100vw;
}

.offcanvas-panel--zuechter {
    width: 520px;
    max-width: 100vw;
}

.offcanvas-panel .offcanvas-header {
    padding: 1.6rem 1.75rem 1rem;
    border-bottom: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.offcanvas-panel .offcanvas-header h4 {
    margin: 0;
}

.offcanvas-panel .offcanvas-body {
    padding: 1.75rem;
}

.offcanvas-panel__lead {
    margin-bottom: 1.25rem;
    color: var(--abc-ink-soft);
}

.offcanvas-inline-alert {
    margin-bottom: 1.25rem;
}

.detail-stack {
    display: grid;
    gap: 1rem;
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.detail-card {
    display: grid;
    gap: 1rem;
    padding: 1.2rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 18px 42px rgba(25, 12, 12, 0.05);
}

.detail-card--hero {
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.12), transparent 22%),
        rgba(255, 255, 255, 0.9);
}

.detail-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.detail-card__header h5 {
    margin: 0;
}

.detail-card__lead {
    margin: 0;
    color: var(--abc-ink-soft);
    line-height: 1.6;
}

.detail-list {
    display: grid;
    gap: 0.85rem;
    margin: 0;
}

.detail-list div {
    display: grid;
    gap: 0.2rem;
}

.detail-list dt {
    color: var(--abc-ink-soft);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.detail-list dd {
    margin: 0;
    font-weight: 600;
    line-height: 1.5;
}

.contribution-year-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.contribution-year-pill {
    border: 1px solid rgba(var(--abc-primary-rgb), 0.16);
}

.contribution-year-pill--current {
    background: rgba(45, 106, 79, 0.12);
    color: var(--abc-success);
    border-color: rgba(45, 106, 79, 0.18);
}

.offcanvas-form {
    align-content: start;
}

@media (max-width: 1199px) {
    .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-action-grid,
    .dashboard-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .workspace-grid {
        grid-template-columns: 1fr;
    }

    .hero-actions {
        grid-template-columns: 1fr;
    }

    .role-grid {
        grid-template-columns: 1fr;
    }

    .role-overview-stats,
    .role-detail-stats,
    .role-group-overview,
    .permission-list {
        grid-template-columns: 1fr;
    }

    .selection-panel--columns {
        grid-template-columns: 1fr;
    }

    .bulk-preview-grid,
    .import-mapping-grid {
        grid-template-columns: 1fr;
    }

    .offcanvas-panel--wide {
        width: min(100vw, 900px);
        min-width: 0;
    }

    .offcanvas-panel--zuechter {
        width: min(100vw, 520px);
    }

    .detail-grid {
        grid-template-columns: 1fr;
    }
}

.campaign-detail-card {
    display: flex;
    flex-direction: column;
}

.campaign-meta-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.25rem;
}

.campaign-meta-list dt {
    margin-bottom: 0.3rem;
    color: var(--abc-ink-soft);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.campaign-meta-list dd {
    margin: 0;
    font-weight: 600;
    line-height: 1.5;
}

.campaign-attachments-panel {
    display: grid;
    gap: 1rem;
    padding-top: 1.35rem;
    border-top: 1px solid rgba(var(--abc-primary-rgb), 0.08);
}

.campaign-attachments-panel__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.campaign-attachments-panel__header h5 {
    margin: 0.2rem 0 0;
}

.campaign-attachment-list {
    display: grid;
    gap: 0.75rem;
}

.campaign-attachment-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.8);
}

.campaign-attachment-item__meta {
    min-width: 0;
}

.campaign-attachment-item__meta strong,
.campaign-attachment-item__meta small {
    display: block;
}

.campaign-attachment-item__meta strong {
    overflow-wrap: anywhere;
}

.campaign-attachment-item__meta small {
    margin-top: 0.25rem;
    color: var(--abc-ink-soft);
    line-height: 1.45;
}

.campaign-attachment-item--active {
    border-color: rgba(var(--abc-primary-rgb), 0.3);
    background: rgba(var(--abc-primary-rgb), 0.04);
}

.campaign-attachment-item__actions {
    display: flex;
    gap: 0.65rem;
    align-items: center;
    flex-wrap: wrap;
    justify-content: end;
    flex: 0 0 auto;
}

.campaign-preview {
    padding: 1.25rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.1);
    border-radius: 22px;
    background: linear-gradient(180deg, #ffffff, #fbf7f4);
    overflow: auto;
}

.campaign-preview-text {
    margin-top: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.03);
}

.campaign-preview-text strong {
    display: block;
    margin-bottom: 0.75rem;
}

.campaign-preview-text pre {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: 'Public Sans', 'Segoe UI', sans-serif;
    color: var(--abc-ink-soft);
}

@media (max-width: 767px) {
    .campaign-attachments-panel__header,
    .campaign-attachment-item {
        flex-direction: column;
        align-items: stretch;
    }

    .campaign-attachment-item__actions {
        justify-content: start;
    }
}

.campaign-composer {
    padding: 1.8rem;
}

.campaign-editor-form {
    margin-top: 1.5rem;
}

.campaign-editor {
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.96);
    overflow: hidden;
}

.campaign-editor__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.6rem;
    padding: 0.85rem;
    border-bottom: 1px solid rgba(var(--abc-primary-rgb), 0.1);
    background: #f8f3f1;
}

.campaign-editor__color-picker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-left: auto;
    color: var(--abc-ink-soft);
    font-size: 0.85rem;
    font-weight: 600;
}

.campaign-editor__color-picker input {
    width: 2.4rem;
    height: 2.1rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    cursor: pointer;
}

.campaign-editor__canvas {
    min-height: 420px;
    padding: 1.25rem 1.35rem;
    font-size: 1rem;
    line-height: 1.75;
    color: var(--abc-ink);
    outline: none;
}

.campaign-editor__canvas:empty::before {
    content: attr(data-placeholder);
    color: rgba(var(--abc-ink-rgb), 0.45);
}

.campaign-editor__canvas p,
.campaign-editor__canvas ul,
.campaign-editor__canvas ol,
.campaign-editor__canvas blockquote,
.campaign-editor__canvas h1,
.campaign-editor__canvas h2,
.campaign-editor__canvas h3 {
    margin: 0 0 1rem;
}

.campaign-editor__canvas ul,
.campaign-editor__canvas ol {
    padding-left: 1.3rem;
}

.campaign-editor__canvas a {
    color: var(--abc-primary);
    text-decoration: underline;
}

.campaign-editor__canvas img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0.75rem 0;
    border-radius: 18px;
    box-shadow: 0 18px 35px rgba(43, 23, 23, 0.12);
}

.campaign-editor__canvas blockquote {
    padding: 0.85rem 1rem;
    border-left: 4px solid rgba(var(--abc-primary-rgb), 0.24);
    background: rgba(var(--abc-primary-rgb), 0.04);
    color: var(--abc-ink-soft);
}

.selector-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.selector-card {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.7);
}

.selector-card h6 {
    margin-bottom: 0.35rem;
}

.selector-card p {
    margin-bottom: 0.85rem;
    color: var(--abc-ink-soft);
}

.selector-list {
    display: grid;
    gap: 0.75rem;
}

.selector-option {
    display: flex;
    align-items: start;
    gap: 0.75rem;
    padding: 0.85rem 0.9rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.94);
}

.selector-option input {
    margin-top: 0.2rem;
}

.selector-option--static {
    justify-content: space-between;
    align-items: center;
}

.selector-option strong,
.selector-option small {
    display: block;
}

.selector-option small {
    margin-top: 0.2rem;
    color: var(--abc-ink-soft);
}

.help-hero {
    align-items: stretch;
}

.help-search-form {
    padding: 1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.1);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.7);
}

.help-search-form__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(220px, 0.8fr) auto;
    gap: 1rem;
    align-items: end;
}

.help-search-form__field {
    min-width: 0;
}

.help-search-form__actions {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
    align-items: center;
}

.help-tips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.help-spotlight-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.help-spotlight-card,
.help-related-card {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    height: 100%;
    padding: 1.2rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 244, 0.9));
    box-shadow: 0 14px 34px rgba(71, 4, 4, 0.08);
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.help-spotlight-card:hover,
.help-related-card:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--abc-primary-rgb), 0.2);
    box-shadow: 0 20px 40px rgba(71, 4, 4, 0.12);
}

.help-spotlight-card strong,
.help-related-card strong {
    font-size: 1.05rem;
}

.help-spotlight-card p,
.help-related-card p {
    margin: 0;
    color: var(--abc-ink-soft);
}

.help-module-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-bottom: 1.5rem;
}

.help-module-chip {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 150px;
    padding: 0.95rem 1.1rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.88);
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.help-module-chip strong {
    font-size: 0.98rem;
}

.help-module-chip span {
    font-size: 0.88rem;
    color: var(--abc-ink-soft);
}

.help-module-chip:hover,
.help-module-chip.is-active {
    transform: translateY(-1px);
    border-color: rgba(var(--abc-primary-rgb), 0.22);
    box-shadow: 0 12px 28px rgba(71, 4, 4, 0.08);
}

.help-module-chip.is-active {
    background: rgba(var(--abc-primary-rgb), 0.08);
}

.help-layout {
    display: grid;
    grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.help-results {
    position: sticky;
    top: 1rem;
}

.help-result-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.help-result-card {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    padding: 1.15rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.1);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 242, 242, 0.88));
    text-decoration: none;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.help-result-card:hover,
.help-result-card.is-active {
    transform: translateY(-1px);
    border-color: rgba(var(--abc-primary-rgb), 0.22);
    box-shadow: 0 18px 34px rgba(71, 4, 4, 0.08);
}

.help-result-card.is-active {
    background: linear-gradient(180deg, rgba(252, 247, 247, 1), rgba(245, 235, 235, 0.92));
}

.help-result-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.help-result-card h4 {
    margin: 0;
    font-size: 1.1rem;
}

.help-result-card p {
    margin: 0;
    color: var(--abc-ink-soft);
    line-height: 1.55;
}

.help-result-card mark {
    padding: 0 0.2rem;
    border-radius: 0.35rem;
    background: rgba(198, 141, 43, 0.28);
}

.help-result-card__keywords {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.help-result-card__keywords span {
    padding: 0.32rem 0.6rem;
    border-radius: 999px;
    background: rgba(var(--abc-primary-rgb), 0.06);
    color: var(--abc-primary-deep);
    font-size: 0.8rem;
    font-weight: 600;
}

.help-results-empty {
    margin-top: 1.25rem;
    padding: 1.2rem;
    border-radius: 18px;
    background: rgba(198, 141, 43, 0.12);
}

.help-results-empty strong,
.help-results-empty p {
    display: block;
}

.help-results-empty p {
    margin: 0.5rem 0 0;
    color: var(--abc-ink-soft);
}

.help-article {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.help-breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    font-size: 0.92rem;
    color: var(--abc-ink-soft);
}

.help-breadcrumbs a {
    text-decoration: none;
}

.help-article__header h3 {
    margin: 0.9rem 0 0;
}

.help-article__lead {
    margin: 0.95rem 0 0;
    color: var(--abc-ink-soft);
    font-size: 1.02rem;
    line-height: 1.65;
}

.help-article__permission-row {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}

.help-article__permission-label {
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--abc-ink-soft);
}

.help-article__permission-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

#overview,
.help-article__panel[id],
.help-workflow-card[id] {
    scroll-margin-top: 1rem;
}

.help-article__panel {
    padding: 1.25rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 245, 245, 0.88));
}

.help-orientation-panel {
    background:
        radial-gradient(circle at top right, rgba(198, 141, 43, 0.16), transparent 36%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(249, 245, 241, 0.94));
}

.help-orientation-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.help-orientation-card {
    padding: 1rem 1.05rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.84);
}

.help-orientation-card__label {
    display: inline-flex;
    margin-bottom: 0.6rem;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--abc-primary);
}

.help-orientation-card p {
    margin: 0;
    line-height: 1.6;
}

.help-toc-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.help-toc-link {
    display: flex;
    align-items: center;
    min-height: 3rem;
    padding: 0.8rem 0.95rem;
    border: 1px solid rgba(var(--abc-primary-rgb), 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.84);
    text-decoration: none;
    transition: border-color 0.18s ease, transform 0.18s ease, background-color 0.18s ease;
}

.help-toc-link:hover {
    transform: translateY(-1px);
    border-color: rgba(var(--abc-primary-rgb), 0.18);
    background: rgba(var(--abc-primary-rgb), 0.04);
}

.help-article__panel p:last-child,
.help-article__panel ul:last-child,
.help-article__panel ol:last-child {
    margin-bottom: 0;
}

.help-highlight-list,
.help-orientation-grid,
.help-toc-list,
.help-workflow-grid,
.help-related-grid {
    display: grid;
    gap: 1rem;
}

.help-highlight-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.help-highlight-card,
.help-workflow-card {
    height: 100%;
    padding: 1rem 1.05rem;
    border-radius: 18px;
    background: rgba(var(--abc-primary-rgb), 0.04);
}

.help-highlight-card p {
    margin: 0;
}

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

.help-workflow-card h5 {
    margin-bottom: 0.85rem;
}

.help-workflow-card ol {
    margin: 0;
    padding-left: 1.25rem;
}

.help-workflow-card li + li {
    margin-top: 0.45rem;
}

.help-bullet-list {
    margin: 1rem 0 0;
    padding-left: 1.25rem;
}

.help-bullet-list li + li {
    margin-top: 0.4rem;
}

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

@media (max-width: 991px) {
    .admin-shell__layout {
        grid-template-columns: 1fr;
    }

    .sidebar {
        gap: 1.25rem;
        padding-bottom: 1.5rem;
    }

    .page-shell,
    .topbar {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .topbar {
        flex-direction: column;
        align-items: stretch;
    }

    .topbar__meta {
        flex-direction: column;
        align-items: stretch;
        justify-content: space-between;
    }

    .topbar__status,
    .topbar__user {
        justify-items: start;
        justify-content: start;
    }

    .hero-card {
        flex-direction: column;
    }

    .offcanvas-panel,
    .offcanvas-panel--wide,
    .offcanvas-panel--zuechter {
        width: 100vw;
        min-width: 0;
    }

    .bulk-field-row {
        grid-template-columns: 1fr;
    }

    .help-search-form__grid,
    .help-layout,
    .help-orientation-grid,
    .help-toc-list,
    .help-workflow-grid,
    .help-related-grid,
    .help-spotlight-grid,
    .help-highlight-list {
        grid-template-columns: 1fr;
    }

    .help-search-form__actions {
        justify-content: stretch;
    }

    .help-search-form__actions .btn {
        width: 100%;
    }

    .help-results {
        position: static;
    }
}

@media (max-width: 767px) {
    .public-shell__flash {
        top: 1rem;
        width: calc(100% - 1rem);
    }

    .public-shell__content {
        padding: 1rem;
    }

    .login-shell {
        grid-template-columns: 1fr;
    }

    .brand-lockup {
        flex-direction: column;
        align-items: start;
    }

    .login-shell__grid,
    .login-card__meta {
        grid-template-columns: 1fr;
    }

    .login-shell__brand,
    .login-card,
    .surface-card,
    .hero-card {
        padding: 1.25rem;
        border-radius: 22px;
    }

    .stats-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-action-grid,
    .dashboard-kpi-grid {
        grid-template-columns: 1fr;
    }

    .hero-card__aside {
        width: 100%;
    }

    .hero-card--profile .dashboard-brief__item strong {
        max-width: 100%;
        text-align: left;
    }

    .dashboard-task {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-bar,
    .filter-bar__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-bar__checkbox,
    .contacts-pagination {
        width: 100%;
    }

    .workspace-intro__meta,
    .bulk-preview-list li {
        flex-direction: column;
        align-items: stretch;
    }

    .management-actions,
    .role-list-item__main,
    .role-list-item__footer,
    .table-actions,
    .role-card__header,
    .role-card__section-head,
    .role-group-overview-card__topline,
    .permission-disclosure__summary,
    .workspace-intro__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .permission-disclosure__meta {
        justify-content: space-between;
    }

    .role-list-item__stats,
    .role-list-item__actions,
    .role-detail-group-meta {
        justify-content: start;
    }

    .impersonation-banner {
        align-items: start;
        flex-direction: column;
    }

    .scope-item {
        flex-direction: column;
        align-items: start;
    }

    .scope-item__meta,
    .topbar__user {
        justify-items: start;
    }

    .contacts-list-table {
        min-width: 860px;
    }

    .contacts-pagination {
        flex-direction: column;
        align-items: stretch;
    }

    .campaign-meta-list,
    .selector-grid {
        grid-template-columns: 1fr;
    }

    .help-module-bar,
    .help-tips {
        flex-direction: column;
    }
}
