@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
    --bg: #0b1220;
    --bg-soft: #111b2f;
    --card: #f7f9fc;
    --text: #0f172a;
    --text-muted: #475569;
    --primary: #4911D8;
    --primary-hover: #3b0eb3;
    --primary-rgb: 73, 17, 216;
    --danger: #b91c1c;
    --border: #dbe4f0;
    --shadow: 0 20px 50px rgba(15, 23, 42, 0.18);
    --focus-outline: rgba(161, 133, 255, 0.92);
    --focus-shadow: 0 0 0 4px rgba(var(--primary-rgb), 0.18);
    --motion-standard: cubic-bezier(0.22, 1, 0.36, 1);
    --motion-emphasized: cubic-bezier(0.16, 1, 0.3, 1);
}

* {
    box-sizing: border-box;
}

body.admin-auth-body {
    margin: 0;
    font-family: "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    color: var(--text);
    min-height: 100vh;
    background:
        radial-gradient(circle at 15% 20%, rgba(73, 17, 216, 0.15), transparent 35%),
        radial-gradient(circle at 85% 5%, rgba(120, 60, 255, 0.12), transparent 30%),
        linear-gradient(160deg, var(--bg), var(--bg-soft));
}

.admin-custom .shell {
    width: min(980px, 92vw);
    margin: 3.5rem auto;
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell.card {
    background: var(--card);
    border-radius: 16px;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, 0.25);
}

.admin-custom .panel {
    padding: 2rem;
}

.admin-custom .title {
    margin: 0;
    font-size: 1.9rem;
    letter-spacing: -0.02em;
}

.admin-custom .subtitle {
    margin: 0.5rem 0 0;
    color: var(--text-muted);
}

.admin-custom .top-nav {
    margin-top: 0.9rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.admin-custom .top-nav .nav-link {
    display: inline-flex;
    align-items: center;
    padding: 0.42rem 0.75rem;
    border-radius: 999px;
    border: 1px solid #cbd5e1;
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    color: #334155;
    background: #f8fafc;
}

.admin-custom .top-nav .nav-link:hover {
    border-color: #94a3b8;
}

.admin-custom .top-nav .nav-link.is-active {
    color: var(--primary);
    border-color: rgba(var(--primary-rgb), 0.3);
    background: rgba(var(--primary-rgb), 0.08);
}

.admin-custom .shell .shell-header,
.admin-custom .shell .header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    height: auto;
    position: static;
    top: auto;
    left: auto;
    right: auto;
    width: auto;
    min-height: 0;
    padding-left: 0;
    border: 0;
    background: transparent;
    z-index: auto;
}

.admin-custom .stack {
    display: grid;
    gap: 1.2rem;
}

.admin-custom .grid {
    display: grid;
    gap: 1rem;
}

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

@media (max-width: 760px) {
    .admin-custom .grid-2 {
        grid-template-columns: 1fr;
    }
}

.admin-custom .section {
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 1.2rem;
    background: #fff;
}

.admin-custom .section h2 {
    margin: 0 0 0.5rem;
    font-size: 1.15rem;
}

.admin-custom .subtitle-strong {
    margin: 0 0 0.45rem;
    font-size: 0.95rem;
    color: #0f172a;
}

.admin-custom .field {
    display: grid;
    gap: 0.4rem;
}

.admin-custom label {
    font-size: 0.92rem;
    font-weight: 600;
    color: #1e293b;
}

.admin-custom input[type="text"],
.admin-custom input[type="number"],
.admin-custom input[type="email"],
.admin-custom input[type="password"],
.admin-custom input[type="file"],
.admin-custom select,
.admin-custom textarea {
    width: 100%;
    padding: 0.72rem 0.78rem;
    border-radius: 10px;
    border: 1px solid #cbd5e1;
    background: #fff;
    font-size: 0.95rem;
}

.admin-custom textarea {
    resize: vertical;
}

.admin-custom input:focus {
    outline: 2px solid rgba(var(--primary-rgb), 0.24);
    outline-offset: 1px;
    border-color: var(--primary);
}

.admin-custom select:focus {
    outline: 2px solid rgba(var(--primary-rgb), 0.24);
    outline-offset: 1px;
    border-color: var(--primary);
}

.admin-custom textarea:focus {
    outline: 2px solid rgba(var(--primary-rgb), 0.24);
    outline-offset: 1px;
    border-color: var(--primary);
}

.admin-custom :where(button, .btn, a[href], [role="button"], .nx-pagination__item):focus-visible,
body.admin-auth-body :where(button, .btn, a[href], .form-check-input):focus-visible {
    outline: 2px solid var(--focus-outline);
    outline-offset: 3px;
    box-shadow: var(--focus-shadow);
}

.admin-custom :where(.btn:disabled, .btn.is-disabled, button[disabled], button[aria-disabled="true"]),
body.admin-auth-body :where(.btn:disabled, button[disabled]) {
    cursor: not-allowed;
    transform: none !important;
}

.admin-custom .field-icon-wrap {
    position: relative;
}

.admin-custom .field-icon {
    position: absolute;
    left: 0.8rem;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    pointer-events: none;
    font-size: 1rem;
    line-height: 1;
}

.admin-custom .field-icon-wrap input {
    padding-left: 2.4rem;
}

.admin-custom .checkbox {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.95rem;
}

.admin-custom .checkbox input {
    width: 17px;
    height: 17px;
}

.admin-custom .shell .actions {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell .btn {
    border: 0;
    border-radius: 10px;
    padding: 0.72rem 1rem;
    cursor: pointer;
    font-weight: 700;
    font-size: 0.92rem;
    transition: transform 0.16s var(--motion-standard), background-color 0.2s var(--motion-standard), color 0.2s var(--motion-standard), opacity 0.18s var(--motion-standard), box-shadow 0.2s var(--motion-standard);
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell .btn:active {
    transform: translateY(1px);
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell .btn-primary {
    background: var(--primary);
    color: #fff;
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell .btn-primary:hover {
    background: var(--primary-hover);
}

body.admin-shell[data-theme-version="light"] .admin-custom .shell .btn-soft {
    background: #e2e8f0;
    color: #1e293b;
}

.admin-custom .status,
.admin-custom .error-box {
    border-radius: 12px;
    padding: 0.8rem 0.95rem;
    font-size: 0.92rem;
}

.admin-custom .status {
    background: #dcfce7;
    border: 1px solid #86efac;
    color: #166534;
}

.admin-custom .error-box {
    background: #fee2e2;
    border: 1px solid #fca5a5;
    color: var(--danger);
}

.admin-custom .error-box ul {
    margin: 0.4rem 0 0 1rem;
    padding: 0;
}

body.admin-shell {
    background: #f5f7fb;
}

body.admin-shell[data-theme-version="dark"] {
    background: #171617;
}

body.admin-shell[data-theme-version="dark"] .content-body {
    background: transparent;
}

body.admin-shell[data-theme-version="dark"] .admin-custom {
    background: transparent;
}

body.admin-shell .content-body {
    min-height: calc(100vh - 90px);
    padding-top: calc(5rem + 1rem);
    padding-bottom: 1.4rem;
}

body.admin-shell .header {
    z-index: 8;
}

body.admin-shell .nav-header {
    z-index: 9;
}

body.admin-shell .header .header-content {
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.admin-shell-header {
    width: 100%;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.admin-shell-header__context {
    display: flex;
    align-items: center;
    gap: 0.78rem;
    min-width: 0;
}

.admin-shell-header__menu-toggle {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid #343d4f;
    background: #1f2634;
    color: #b6c2da;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.28rem;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.admin-shell-header__menu-toggle:hover {
    border-color: #4f5f7f;
    background: #293143;
    color: #e2e8f8;
}

.admin-shell-header__menu-toggle.is-active {
    border-color: var(--primary);
    color: #f1edff;
    background: rgba(var(--primary-rgb), 0.18);
}

.admin-shell-header__title-wrap {
    min-width: 0;
    display: grid;
    gap: 0.16rem;
}

.admin-shell-header__breadcrumb {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    margin: 0;
    color: #8f9ab2;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.admin-shell-header__breadcrumb a {
    color: #9faccb;
    text-decoration: none;
}

.admin-shell-header__breadcrumb a:hover {
    color: #d7e0f2;
}

.admin-shell-header__breadcrumb-separator {
    color: #66738f;
}

.admin-shell-header__breadcrumb .is-current {
    color: #d6deee;
}

.admin-shell-header__title {
    margin: 0;
    color: #f2f6ff;
    font-size: 1.08rem;
    letter-spacing: 0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-shell-header__actions {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: nowrap;
}

.admin-shell-sync {
    min-height: 42px;
    display: grid;
    align-content: center;
    gap: 0.16rem;
    padding: 0 0.45rem 0 0.95rem;
    border-left: 1px solid #32405c;
}

.admin-shell-sync small {
    color: #a6b4cd;
    font-size: 0.74rem;
    line-height: 1;
}

.admin-shell-sync strong {
    color: #7fb3ff;
    font-size: 0.85rem;
    font-weight: 700;
    line-height: 1;
}

.admin-shell-sync__progress {
    height: 0.22rem;
    margin: 0;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.2);
    min-width: 115px;
}

.admin-shell-sync__progress .progress-bar {
    border-radius: 999px;
}

.admin-shell-sync__progress-label {
    color: #91a2c0;
    font-size: 0.64rem;
    line-height: 1;
}

.admin-shell-header__user {
    border-radius: 999px;
    border: 1px solid #33415a;
    background: #1c2434;
    padding: 0.22rem 0.55rem 0.22rem 0.24rem;
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
}

.admin-shell-header__avatar {
    width: 29px;
    height: 29px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, #3b0eb3, #4911D8);
    color: #f8fbff;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.03em;
}

.admin-shell-header__user-meta {
    display: grid;
    gap: 0.05rem;
    line-height: 1.1;
}

.admin-shell-header__user-meta strong {
    color: #f2f7ff;
    font-size: 0.74rem;
    font-weight: 700;
}

.admin-shell-header__user-meta small {
    color: #94a2bc;
    font-size: 0.64rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-shell-mobile-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
    border: 0;
    margin: 0;
    padding: 0;
    background: rgba(7, 11, 20, 0.6);
    backdrop-filter: blur(2px);
}

.admin-shell-menu-tag {
    margin-left: 0.4rem;
    border-radius: 999px;
    border: 1px solid rgba(140, 156, 189, 0.38);
    padding: 0.05rem 0.36rem;
    font-size: 0.62rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #a3b0cb;
}

.admin-shell-sidebar-scroll {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.admin-shell-menu {
    flex: 1 1 auto;
}

body.admin-shell .deznav .menu-title {
    margin: 1.1rem 0 0.48rem;
    padding: 0 1.2rem;
    color: #8f9ab2;
    font-size: 0.68rem;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    font-weight: 700;
}

body.admin-shell .deznav .menu-title:first-child {
    margin-top: 0.35rem;
}

.admin-shell-sidebar-footer {
    padding: 0.78rem 1rem 1rem;
    border-top: 1px solid #2d3545;
    margin-top: 0.85rem;
}

.admin-shell-sidebar-user {
    display: flex;
    align-items: center;
    gap: 0.56rem;
    margin-bottom: 0.58rem;
}

.admin-shell-sidebar-avatar {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, #3b0eb3, #4911D8);
    color: #f9fbff;
    font-size: 0.72rem;
    font-weight: 800;
}

.admin-shell-sidebar-user-meta {
    min-width: 0;
    display: grid;
    line-height: 1.1;
    gap: 0.08rem;
}

.admin-shell-sidebar-user-meta p {
    margin: 0;
    color: #e3eaf8;
    font-size: 0.79rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-shell-sidebar-user-meta small {
    color: #96a3be;
    font-size: 0.67rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-shell-sidebar-logout-form {
    margin: 0;
}

.admin-shell-sidebar-logout {
    width: 100%;
    border-radius: 10px;
    border: 1px solid #37445f;
    background: #202938;
    color: #d7dfef;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.36rem;
    padding: 0.5rem 0.62rem;
}

.admin-shell-sidebar-logout:hover {
    border-color: #506283;
    background: #283245;
    color: #f1f6ff;
}

@media (min-width: 992px) {
    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-footer {
        padding: 0.7rem 0.45rem 0.85rem;
        display: grid;
        justify-items: center;
        gap: 0.5rem;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-user {
        margin: 0;
        justify-content: center;
        width: 100%;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-user-meta {
        display: none;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-logout-form {
        width: 100%;
        display: flex;
        justify-content: center;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-logout {
        width: 38px;
        min-width: 38px;
        height: 38px;
        min-height: 38px;
        padding: 0;
        border-radius: 10px;
        gap: 0;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-logout-label {
        display: none;
    }

    body.admin-shell[data-sidebar-style="full"][data-layout="vertical"] #main-wrapper.menu-toggle .admin-shell-sidebar-logout i {
        margin: 0;
        font-size: 1rem;
    }
}

@media (max-width: 1200px) {
    .admin-shell-header__user-meta {
        display: none;
    }

    .admin-shell-header__user {
        padding-right: 0.3rem;
    }

    .admin-shell-header__title {
        max-width: 290px;
    }
}

@media (max-width: 991px) {
    body.admin-shell .content-body {
        padding-top: calc(5rem + 0.7rem);
    }

    body.admin-shell .header .header-content {
        padding-left: 0.72rem !important;
        padding-right: 0.72rem;
    }

    .admin-shell-header__breadcrumb {
        display: none;
    }

    .admin-shell-header__title {
        max-width: 200px;
        font-size: 0.96rem;
    }

    .admin-shell-sync {
        display: none;
    }

    body.admin-shell .deznav {
        width: min(280px, 84vw);
        transform: translateX(-108%);
        transition: transform 0.24s ease;
        z-index: 1048;
    }

    body.admin-shell #main-wrapper.menu-toggle .deznav {
        transform: translateX(0);
    }

    body.admin-shell.admin-shell-mobile-nav-open {
        overflow: hidden;
    }
}

@media (max-width: 760px) {
    .admin-shell-header {
        gap: 0.45rem;
    }

    .admin-shell-header__context {
        gap: 0.5rem;
    }

    .admin-shell-header__menu-toggle {
        width: 36px;
        height: 36px;
        border-radius: 10px;
        font-size: 1.12rem;
    }

    .admin-shell-header__actions {
        gap: 0.45rem;
    }

    .admin-shell-header__user {
        display: none;
    }

    .sri-env-switch {
        min-height: 40px;
        border-radius: 14px;
        padding: 0.2rem;
    }

    .sri-env-switch__icon {
        width: 34px;
        min-height: 30px;
        border-radius: 10px;
    }

    .sri-env-switch__option {
        min-width: 76px;
        min-height: 30px;
        font-size: 0.77rem;
        padding: 0.34rem 0.64rem;
    }

    .admin-live-alert__trigger {
        width: 38px;
        height: 38px;
        border-radius: 10px;
    }

    .admin-live-alert__panel {
        width: 100vw;
        border-radius: 0;
    }

    .admin-live-alert__toasts {
        left: 10px;
        right: 10px;
        width: auto;
    }

    .admin-critical-banner {
        grid-template-columns: 1fr;
        align-items: flex-start;
        gap: 0.6rem;
        padding: 0.72rem 0.8rem;
    }

    .admin-critical-banner__icon {
        width: 32px;
        height: 32px;
    }

    .admin-critical-banner__actions {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

body.admin-shell .admin-custom .shell {
    width: 100%;
    max-width: none;
    margin: 0;
}

body.admin-shell .nav-header .brand-logo {
    gap: 0.55rem;
}

body.admin-shell .nav-header .logo-abbr {
    width: 2rem;
    height: 2rem;
    border-radius: 0.6rem;
    background: var(--primary);
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
}

body.admin-shell .nav-header .logo-abbr i {
    font-size: 1.64rem;
    line-height: 1;
}

body.admin-shell .nav-header .brand-title {
    margin-left: 0;
    max-width: none;
    font-size: 0.9rem;
    line-height: 1.08;
    color: #f8fafc;
}

body.admin-shell .nav-header .brand-title strong {
    font-size: 0.9rem;
    color: #f8fafc;
}

body.admin-shell .nav-header .brand-title small {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #c1c3ca;
}

body.admin-shell .deznav .menu-icon {
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 8px;
    border: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: #7c889b;
    margin-right: 0.5rem;
    background: transparent;
    transition: color 0.2s ease, background-color 0.2s ease;
    flex-shrink: 0;
}

body.admin-shell .deznav .metismenu > li.mm-active > a .menu-icon {
    border-color: rgba(var(--primary-rgb), 0.35);
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.1);
}

body.admin-shell .deznav a[aria-disabled="true"] {
    opacity: 0.55;
    pointer-events: none;
}

.admin-custom .brand-title {
    display: inline-flex;
    flex-direction: column;
    gap: 0;
    line-height: 1.05;
}

.admin-custom .brand-main {
    color: var(--primary);
    font-weight: 700;
    font-size: 1.02rem;
}

.admin-custom .brand-sub {
    color: #6f767e;
    font-size: 0.72rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.admin-live-alert {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.admin-critical-banner {
    width: 100%;
    margin: 0 0 1rem;
    border-radius: 14px;
    border: 1px solid rgba(252, 165, 165, 0.55);
    background: linear-gradient(135deg, rgba(127, 29, 29, 0.96), rgba(153, 27, 27, 0.96));
    box-shadow: 0 16px 30px rgba(127, 29, 29, 0.3);
    color: #fef2f2;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.85rem;
    padding: 0.78rem 0.92rem;
}

.admin-critical-banner[hidden] {
    display: none !important;
}

.admin-critical-banner__icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid rgba(254, 202, 202, 0.55);
    background: rgba(127, 29, 29, 0.45);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.18rem;
}

.admin-critical-banner__content {
    min-width: 0;
    display: grid;
    gap: 0.2rem;
}

.admin-critical-banner__title {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: #fff1f2;
}

.admin-critical-banner__message {
    margin: 0;
    font-size: 0.84rem;
    color: #fecdd3;
    line-height: 1.35;
}

.admin-critical-banner__meta {
    color: rgba(254, 205, 211, 0.86);
    font-size: 0.72rem;
    line-height: 1.1;
}

.admin-critical-banner__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.admin-custom .admin-critical-banner__actions .btn.admin-critical-banner__link,
.admin-custom .admin-critical-banner__actions .btn.admin-critical-banner__dismiss {
    background: rgba(127, 29, 29, 0.5);
    border: 1px solid rgba(254, 202, 202, 0.45);
    color: #ffe4e6;
    font-size: 0.75rem;
    padding: 0.45rem 0.68rem;
    border-radius: 10px;
}

.admin-custom .admin-critical-banner__actions .btn.admin-critical-banner__link:hover,
.admin-custom .admin-critical-banner__actions .btn.admin-critical-banner__dismiss:hover {
    background: rgba(153, 27, 27, 0.6);
    border-color: rgba(254, 205, 211, 0.75);
    color: #fff1f2;
}

.admin-live-alert__backdrop {
    position: fixed;
    inset: 0;
    z-index: 1058;
    border: 0;
    margin: 0;
    padding: 0;
    background: rgba(7, 11, 20, 0.48);
    backdrop-filter: blur(1.5px);
}

.sri-env-switch {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    border-radius: 16px;
    border: 1px solid #31405a;
    background: #1b2434;
    padding: 0.28rem;
    gap: 0.28rem;
}

.sri-env-switch__icon {
    width: 44px;
    min-height: 38px;
    border-radius: 12px;
    border-right: 1px solid #2f3b53;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #d4d9e6;
    font-size: 1.15rem;
}

.sri-env-switch__item {
    margin: 0;
    display: inline-flex;
}

.sri-env-switch__option {
    border: 1px solid transparent;
    background: transparent;
    color: #9aa6bc;
    border-radius: 12px;
    min-height: 38px;
    min-width: 150px;
    padding: 0.45rem 1.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 0.98rem;
    font-weight: 700;
    line-height: 1;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.sri-env-switch__option:hover {
    border-color: #3f506f;
    background: rgba(65, 84, 118, 0.24);
    color: #dce3f3;
}

.sri-env-switch__option.is-active {
    color: #f8faff;
    border-color: rgba(var(--primary-rgb), 0.7);
    background: linear-gradient(135deg, rgba(59, 14, 179, 0.9), rgba(73, 17, 216, 0.95));
}

.sri-env-switch__option--production.is-active {
    border-color: rgba(97, 199, 136, 0.75);
    background: linear-gradient(135deg, rgba(79, 166, 106, 0.95), rgba(101, 192, 127, 0.96));
}

.sri-env-switch__option.is-planned {
    border-color: rgba(var(--primary-rgb), 0.45);
    color: #d4dff6;
    background: rgba(var(--primary-rgb), 0.22);
}

.sri-env-switch__option.is-disabled {
    cursor: not-allowed;
    opacity: 0.82;
}

.admin-live-alert__trigger {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: 1px solid #333845;
    background: #212733;
    color: #aeb8ca;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    position: relative;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.admin-live-alert__trigger:hover {
    background: #28303e;
    border-color: #42506a;
    color: #dce4f3;
}

.admin-live-alert__count {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 20px;
    height: 20px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ef4444;
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    border: 2px solid #171617;
}

.admin-live-alert__panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(390px, 90vw);
    border-radius: 14px 0 0 14px;
    border: 1px solid #2f3646;
    border-right: 0;
    background: linear-gradient(160deg, #171d2b 0%, #141b29 100%);
    box-shadow: 0 20px 42px rgba(3, 8, 20, 0.56);
    z-index: 1060;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.22s ease, opacity 0.22s ease;
}

.admin-live-alert.is-open .admin-live-alert__panel {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.admin-live-alert__panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    padding: 0.82rem 0.95rem;
    border-bottom: 1px solid #2c3445;
    color: #dce3f2;
}

.admin-live-alert__panel-title {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.admin-live-alert__panel-title strong {
    font-size: 1.03rem;
    letter-spacing: 0.01em;
}

.admin-live-alert__panel-title-icon {
    color: var(--primary);
    font-size: 0.95rem;
}

.admin-live-alert__panel-controls {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.admin-live-alert__panel-controls small {
    color: #8f9ab2;
    font-size: 0.72rem;
}

.admin-live-alert__panel-close {
    width: 24px;
    height: 24px;
    border-radius: 6px;
    border: 1px solid transparent;
    background: transparent;
    color: #8d97ab;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
}

.admin-live-alert__panel-close:hover {
    color: #d8dfed;
    border-color: #3a4357;
    background: rgba(56, 66, 84, 0.32);
}

.admin-live-alert__list {
    position: relative;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0.85rem 0.9rem 0.9rem;
    display: grid;
    gap: 0.7rem;
}

.admin-live-alert__list::before {
    content: '';
    position: absolute;
    top: 0.85rem;
    bottom: 0.9rem;
    left: 12px;
    width: 1px;
    background: linear-gradient(180deg, rgba(91, 112, 158, 0.42), rgba(57, 75, 114, 0.14));
    pointer-events: none;
}

.admin-live-alert__item {
    position: relative;
    padding-left: 1.45rem;
}

.admin-live-alert__item-dot {
    position: absolute;
    left: 7px;
    top: 16px;
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: #54617d;
    border: 2px solid #171d2b;
}

.admin-live-alert__item-card {
    border-radius: 11px;
    border: 1px solid #2f374a;
    background: #1f2636;
    padding: 0.62rem 0.75rem 0.66rem;
    box-shadow: inset 3px 0 0 rgba(83, 96, 123, 0.42);
}

.admin-live-alert__item-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
    margin-bottom: 0.26rem;
}

.admin-live-alert__item-meta small {
    font-size: 0.7rem;
    color: #8c98b2;
    font-weight: 600;
}

.admin-live-alert__item-meta span {
    border-radius: 999px;
    padding: 0.1rem 0.45rem;
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #96a6c6;
    background: rgba(72, 84, 111, 0.26);
}

.admin-live-alert__item-top {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.28rem;
}

.admin-live-alert__item-top strong {
    font-size: 0.88rem;
    color: #ecf1fb;
    line-height: 1.2;
}

.admin-live-alert__item-card p {
    margin: 0;
    font-size: 0.79rem;
    color: #b4bfd6;
    line-height: 1.35;
}

.admin-live-alert__item--danger .admin-live-alert__item-dot {
    background: #fb5d67;
}

.admin-live-alert__item--danger .admin-live-alert__item-card {
    border-color: rgba(251, 93, 103, 0.5);
    box-shadow: inset 3px 0 0 rgba(251, 93, 103, 0.9);
}

.admin-live-alert__item--danger .admin-live-alert__item-meta span {
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.admin-live-alert__item--warning .admin-live-alert__item-dot {
    background: #f6c657;
}

.admin-live-alert__item--warning .admin-live-alert__item-card {
    border-color: rgba(246, 198, 87, 0.45);
    box-shadow: inset 3px 0 0 rgba(246, 198, 87, 0.88);
}

.admin-live-alert__item--warning .admin-live-alert__item-meta span {
    color: #fde68a;
    background: rgba(146, 64, 14, 0.34);
}

.admin-live-alert__item--success .admin-live-alert__item-dot {
    background: #3ddc84;
}

.admin-live-alert__item--success .admin-live-alert__item-card {
    border-color: rgba(61, 220, 132, 0.45);
    box-shadow: inset 3px 0 0 rgba(61, 220, 132, 0.86);
}

.admin-live-alert__item--success .admin-live-alert__item-meta span {
    color: #bbf7d0;
    background: rgba(22, 101, 52, 0.3);
}

.admin-live-alert__item--info .admin-live-alert__item-dot {
    background: #7d91bc;
}

.admin-live-alert__empty {
    margin: 0;
    padding: 0.72rem;
    border-radius: 10px;
    border: 1px dashed #344056;
    color: #9aa4b8;
    font-size: 0.8rem;
}

.admin-live-alert__panel-footer {
    padding: 0.6rem 0.9rem 0.9rem;
}

.admin-live-alert__panel-link {
    display: inline-flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: 1px solid #2f3a52;
    background: #1d2535;
    padding: 0.58rem 0.8rem;
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 700;
    color: #9aa8c4;
}

.admin-live-alert__panel-link:hover {
    border-color: #3f4b66;
    color: #d8e1f2;
    background: #232d41;
}

.admin-live-alert__toasts {
    position: fixed;
    bottom: 18px;
    right: 18px;
    width: min(420px, calc(100vw - 20px));
    display: grid;
    gap: 0.55rem;
    z-index: 1080;
    pointer-events: none;
}

.admin-live-alert__toast {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    border: 1px solid #334155;
    background: linear-gradient(140deg, #202836, #1a2130);
    box-shadow: 0 18px 34px rgba(2, 6, 23, 0.5);
    padding: 0.82rem 0.9rem;
    color: #e6edf8;
    pointer-events: auto;
    transition: opacity 0.18s ease, transform 0.18s ease;
    transform: translateY(0);
    animation: adminLiveToastIn 0.26s ease-out;
}

.admin-live-alert__toast::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 5px;
    background: #64748b;
}

.admin-live-alert__toast strong {
    display: block;
    margin-bottom: 0.18rem;
    font-size: 0.92rem;
    letter-spacing: 0.01em;
    color: #f8fafc;
}

.admin-live-alert__toast p {
    margin: 0;
    font-size: 0.84rem;
    color: #d6deec;
}

.admin-live-alert__toast--danger {
    border-color: rgba(248, 113, 113, 0.62);
    background: linear-gradient(140deg, rgba(185, 28, 28, 0.94), rgba(127, 29, 29, 0.94));
}

.admin-live-alert__toast--danger::before {
    background: #fecaca;
}

.admin-live-alert__toast--warning {
    border-color: rgba(252, 211, 77, 0.68);
    background: linear-gradient(140deg, rgba(217, 119, 6, 0.94), rgba(146, 64, 14, 0.94));
}

.admin-live-alert__toast--warning::before {
    background: #fef3c7;
}

.admin-live-alert__toast--success {
    border-color: rgba(74, 222, 128, 0.62);
    background: linear-gradient(140deg, rgba(22, 163, 74, 0.96), rgba(21, 128, 61, 0.96));
}

.admin-live-alert__toast--success::before {
    background: #dcfce7;
}

.admin-live-alert__toast--info {
    border-color: rgba(96, 165, 250, 0.62);
    background: linear-gradient(140deg, rgba(30, 64, 175, 0.94), rgba(30, 58, 138, 0.94));
}

.admin-live-alert__toast--info::before {
    background: #bfdbfe;
}

.admin-live-alert__toast.is-leaving {
    opacity: 0;
    transform: translateY(10px);
}

@keyframes adminLiveToastIn {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

body.app-confirm-open {
    overflow: hidden;
}

.app-confirm {
    position: fixed;
    inset: 0;
    z-index: 1300;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.app-confirm[hidden] {
    display: none !important;
}

.app-confirm__backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(7, 10, 17, 0.72);
    backdrop-filter: blur(2px);
}

.app-confirm__dialog {
    position: relative;
    width: min(520px, 94vw);
    border-radius: 16px;
    border: 1px solid #373f52;
    background: #1d2330;
    box-shadow: 0 24px 50px rgba(2, 6, 23, 0.48);
    padding: 1.2rem 1.25rem 1rem;
    color: #e6edf8;
}

.app-confirm__header h2 {
    margin: 0;
    font-size: 1.38rem;
    color: #f8fbff;
}

.app-confirm__message {
    margin: 0.6rem 0 1rem;
    color: #d2dced;
    font-size: 1.02rem;
    line-height: 1.42;
}

.app-confirm__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.6rem;
}

.app-confirm__actions .btn {
    min-width: 110px;
    border-radius: 12px;
    font-weight: 700;
}

.app-confirm__accept {
    border: 1px solid transparent;
    background: #4f36ff;
    color: #eef2ff;
}

.app-confirm__accept:hover {
    background: #644eff;
    color: #f7f9ff;
}

.app-confirm--danger .app-confirm__accept {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(127, 29, 29, 0.82);
    color: #fee2e2;
}

.app-confirm--danger .app-confirm__accept:hover {
    border-color: rgba(248, 113, 113, 0.65);
    background: rgba(127, 29, 29, 0.96);
}

.app-confirm--warning .app-confirm__accept {
    border-color: rgba(252, 211, 77, 0.5);
    background: rgba(120, 74, 13, 0.9);
    color: #fef3c7;
}

.app-confirm--warning .app-confirm__accept:hover {
    border-color: rgba(252, 211, 77, 0.7);
    background: rgba(120, 74, 13, 1);
}

.app-confirm--neutral .app-confirm__accept {
    border-color: rgba(148, 163, 184, 0.52);
    background: rgba(51, 65, 85, 0.92);
    color: #e2e8f0;
}

.app-confirm--neutral .app-confirm__accept:hover {
    border-color: rgba(148, 163, 184, 0.7);
    background: rgba(51, 65, 85, 1);
}

.admin-user-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid #dbe4f0;
    background: #fff;
    color: #344054;
    font-size: 0.8rem;
    padding: 0.28rem 0.62rem;
    font-weight: 600;
}

body.admin-shell .deznav .menu-icon i {
    font-size: 1.05rem;
    color: #6f767e;
}

body.admin-shell .deznav .mm-active > a .menu-icon i,
body.admin-shell .deznav .mm-active > a .nav-text {
    color: var(--primary) !important;
}

.admin-custom .muted {
    color: var(--text-muted);
    margin: 0;
}

.admin-custom .stack-sm {
    display: grid;
    gap: 0.75rem;
}

.admin-custom .step-grid {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-custom .step-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.35rem 0.55rem;
    border: 1px solid #cbd5e1;
    background: #f8fafc;
    color: #334155;
    font-size: 0.8rem;
    font-weight: 700;
}

.admin-custom .step-pill.is-done {
    border-color: #10b981;
    background: #dcfce7;
    color: #166534;
}

.admin-custom .step-pill.is-pending {
    border-color: #fdba74;
    background: #fff7ed;
    color: #9a3412;
}

.admin-custom .list {
    margin: 0;
    padding-left: 1.1rem;
    color: #1e293b;
}

.admin-custom .code-block {
    margin: 0;
    border-radius: 10px;
    border: 1px solid #1e293b;
    background: #0f172a;
    color: #cbd5e1;
    font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.77rem;
    line-height: 1.45;
    padding: 0.85rem;
    max-height: 360px;
    overflow: auto;
    white-space: pre;
}

.admin-custom .code-tree {
    line-height: 1.5;
}

.admin-custom .xml-tree-line {
    display: block;
    color: #cbd5e1;
}

.admin-custom .xml-tree-line-todo {
    color: #fca5a5;
    font-weight: 700;
}

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

.admin-custom .factura-visual {
    display: grid;
    gap: 1rem;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.admin-custom .factura-banner {
    border: 1px solid #334155;
    border-radius: 12px;
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    color: #e2e8f0;
    padding: 1rem;
}

.admin-custom .factura-banner h2 {
    margin: 0.25rem 0;
    color: #fff;
}

.admin-custom .badge {
    display: inline-flex;
    margin: 0;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: rgba(255, 255, 255, 0.2);
}

.admin-custom .table-wrap {
    overflow-x: auto;
}

.admin-custom .factura-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.admin-custom .factura-table th,
.admin-custom .factura-table td {
    text-align: left;
    padding: 0.65rem;
    border-bottom: 1px solid #e2e8f0;
}

.admin-custom .factura-table th {
    background: #f1f5f9;
    color: #1e293b;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.admin-custom .summary-grid {
    display: grid;
    gap: 0.45rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0.9rem;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
}

.admin-custom .code-details {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.5rem;
    background: #fff;
}

.admin-custom .code-details summary {
    cursor: pointer;
    font-weight: 600;
    color: #1e293b;
}

.admin-custom .dashboard-screen.shell {
    width: 100%;
    max-width: none;
    margin: 0;
}

body.admin-shell .dashboard-screen.shell.card {
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.admin-shell .dashboard-screen.panel {
    padding: 0;
}

.admin-custom .dashboard-header {
    align-items: flex-start;
}

.admin-custom .dashboard-header .title {
    margin-top: 0.2rem;
}

.admin-custom .dashboard-header .subtitle {
    max-width: 700px;
}

.admin-custom .dashboard-section-title {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.admin-custom .dashboard-kpi-head {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.admin-custom .dashboard-kpi-head .subtitle-strong {
    margin: 0;
}

.admin-custom .dashboard-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1;
    border: 0;
    flex-shrink: 0;
}

.admin-custom .dashboard-icon i {
    font-size: 1.05rem;
    line-height: 1;
}

.admin-custom .dashboard-icon--teal {
    color: #0f766e;
    background: rgba(15, 118, 110, 0.1);
}

.admin-custom .dashboard-icon--blue {
    color: #1d4ed8;
    background: rgba(29, 78, 216, 0.1);
}

.admin-custom .dashboard-icon--amber {
    color: #b45309;
    background: rgba(180, 83, 9, 0.1);
}

.admin-custom .dashboard-icon--rose {
    color: #be123c;
    background: rgba(190, 18, 60, 0.1);
}

.admin-custom .dashboard-icon--slate {
    color: #334155;
    background: rgba(51, 65, 85, 0.1);
}

.admin-custom .dashboard-icon--green {
    color: #166534;
    background: rgba(22, 101, 52, 0.1);
}

.admin-custom .dashboard-actions .btn {
    min-width: 190px;
    justify-content: center;
}

.admin-custom .dashboard-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.8rem;
}

.admin-custom .dashboard-kpi-card,
.admin-custom .dashboard-health-card,
.admin-custom .dashboard-alert-item,
.admin-custom .dashboard-shortcut-card,
.admin-custom .dashboard-state-card {
    border-radius: 12px;
}

.admin-custom .dashboard-kpi-value {
    margin: 0.15rem 0 0;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.admin-custom .dashboard-card-link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.admin-custom .dashboard-card-link:hover,
.admin-custom .dashboard-card-link:focus-visible {
    color: inherit;
    text-decoration: none;
}

.admin-custom .dashboard-kpi-card--interactive,
.admin-custom .dashboard-health-card--interactive {
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.admin-custom .dashboard-card-link:hover .dashboard-kpi-card--interactive,
.admin-custom .dashboard-card-link:hover .dashboard-health-card--interactive {
    border-color: rgba(var(--primary-rgb), 0.35);
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(var(--primary-rgb), 0.14);
}

.admin-custom .dashboard-card-link:focus-visible .dashboard-kpi-card--interactive,
.admin-custom .dashboard-card-link:focus-visible .dashboard-health-card--interactive {
    outline: 2px solid rgba(var(--primary-rgb), 0.6);
    outline-offset: 2px;
}

.admin-custom .dashboard-basic-line-chart {
    display: block;
    width: 100%;
    height: 30px;
    margin-top: 0.35rem;
}

.admin-custom .dashboard-sparkline {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.24rem;
    align-items: end;
    height: 26px;
    margin-top: 0.25rem;
}

.admin-custom .dashboard-sparkline span {
    height: var(--v);
    min-height: 4px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.9), rgba(59, 14, 179, 0.85));
    opacity: 0.95;
}

.admin-custom .dashboard-health-alerts-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.admin-custom .dashboard-alerts-grid {
    grid-template-columns: 1fr;
    gap: 0.9rem;
}

.admin-custom .dashboard-bottom-grid {
    grid-template-columns: 1fr 4fr;
    gap: 1rem;
    align-items: start;
}

.admin-custom .dashboard-shortcuts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.admin-custom .dashboard-shortcuts-title {
    margin: 0 0 1rem;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.admin-custom .dashboard-shortcut-card {
    padding: 0;
    overflow: hidden;
}

.admin-custom .dashboard-shortcut-link {
    width: 100%;
    aspect-ratio: 1 / 1;
    min-height: 0;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.9rem;
    text-align: center;
    text-decoration: none;
    color: inherit;
    border-radius: 12px;
    transition: background-color 0.2s ease, transform 0.15s ease, border-color 0.2s ease;
}

.admin-custom .dashboard-shortcut-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.1);
}

.admin-custom .dashboard-shortcut-link:focus-visible {
    outline: 2px solid rgba(var(--primary-rgb), 0.55);
    outline-offset: -2px;
}

.admin-custom .dashboard-shortcut-icon {
    width: 3rem;
    height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.1rem;
    color: #6b7280;
}

.admin-custom .dashboard-shortcut-label {
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.2;
    color: #334155;
}

.admin-custom .dashboard-states-grid {
    gap: 0.75rem;
}

.admin-custom .dashboard-empty-state {
    border-style: dashed;
}

@media (max-width: 1400px) {
    .admin-custom .dashboard-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1200px) {
    .admin-custom .dashboard-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-custom .dashboard-health-alerts-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-custom .dashboard-alerts-panel {
        grid-column: 1 / -1;
    }

    .admin-custom .dashboard-bottom-grid {
        grid-template-columns: 1fr;
    }

    .admin-custom .dashboard-shortcuts-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 920px) {
    .admin-custom .dashboard-health-alerts-row,
    .admin-custom .dashboard-states-grid {
        grid-template-columns: 1fr;
    }

    .admin-custom .dashboard-alerts-panel {
        grid-column: auto;
    }
}

@media (max-width: 760px) {
    .admin-custom .dashboard-kpi-grid {
        grid-template-columns: 1fr;
    }

    .admin-custom .dashboard-shortcuts-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 420px) {
    .admin-custom .dashboard-shortcuts-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .admin-custom .step-grid {
        grid-template-columns: 1fr;
    }

    .admin-custom .meta-grid {
        grid-template-columns: 1fr;
    }

    .admin-custom .summary-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 920px) {
    .admin-custom .dashboard-screen .shell-header,
    .admin-custom .dashboard-screen .header {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 1rem;
    }

    .admin-custom .dashboard-screen .actions {
        width: 100%;
    }

    .admin-custom .dashboard-screen .actions .btn {
        flex: 1 1 220px;
        text-align: center;
    }
}

@media (max-width: 640px) {
    .admin-custom .dashboard-screen.shell {
        width: 100%;
        margin: 0;
    }

    .admin-custom .dashboard-screen .panel {
        padding: 1.05rem;
    }

    .admin-custom .dashboard-screen .section {
        padding: 0.9rem;
    }

    .admin-custom .dashboard-screen .factura-table th,
    .admin-custom .dashboard-screen .factura-table td {
        padding: 0.5rem;
        font-size: 0.82rem;
    }
}

.authincation {
    min-height: 100vh;
    padding: 1.25rem;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #edf1f6;
    font-family: "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
}

.authincation .container-fluid {
    width: min(1240px, 100%);
}

.authincation .row {
    min-height: 700px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 24px 56px rgba(15, 23, 42, 0.2);
}

.authincation .pages-left {
    height: 100%;
    padding: 2.8rem;
    color: #dbeafe;
    background:
        radial-gradient(circle at 20% 10%, rgba(73, 17, 216, 0.22), transparent 38%),
        radial-gradient(circle at 85% 85%, rgba(120, 60, 255, 0.1), transparent 30%),
        linear-gradient(150deg, #111318 0%, #1c2741 45%, #233a63 100%);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.authincation .login-content {
    max-width: 500px;
}

.template-wordmark {
    font-size: 2rem;
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #ffffff;
}

.auth-brand-title {
    margin: 1rem 0 0;
    font-size: 2.35rem;
    line-height: 1.15;
    letter-spacing: -0.03em;
    color: #f8fafc;
}

.authincation .login-content p {
    margin: 1rem 0 0;
    color: #cbd5e1;
    line-height: 1.6;
    font-size: 1.02rem;
}

.auth-brand-tags {
    margin-top: 1.1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.auth-brand-tags span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.35);
    background: rgba(255, 255, 255, 0.08);
    color: #e2e8f0;
    padding: 0.32rem 0.75rem;
    font-size: 0.78rem;
    font-weight: 600;
}

.template-illustration {
    margin-top: 1.4rem;
    border-radius: 14px;
    border: 1px solid rgba(148, 163, 184, 0.32);
    background: rgba(255, 255, 255, 0.08);
    padding: 0.85rem;
}

.template-illustration svg {
    width: 100%;
    height: auto;
    display: block;
}

.auth-form-column {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    padding: 2.2rem;
}

.authincation .login-form {
    width: min(470px, 100%);
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);
    padding: 2.15rem;
}

.authincation .text-center {
    text-align: center;
}

.authincation .mb-1 {
    margin-bottom: 0.45rem;
}

.authincation .mb-2 {
    margin-bottom: 0.65rem;
}

.authincation .mb-3 {
    margin-bottom: 0.85rem;
}

.authincation .mb-4 {
    margin-bottom: 1rem;
}

.authincation .d-grid {
    display: grid;
}

.authincation .login-form .title {
    margin: 0;
    color: #0f172a;
    font-size: 2.1rem;
    letter-spacing: -0.03em;
}

.authincation .login-form p {
    margin-top: 0.6rem;
    color: #64748b;
}

.auth-alert {
    border-radius: 12px;
    border: 1px solid transparent;
    padding: 0.85rem 0.95rem;
    margin: 0.95rem 0 1rem;
    font-size: 0.9rem;
}

.auth-alert p {
    margin: 0.45rem 0 0;
    color: inherit;
}

.auth-alert--danger {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

.auth-alert--warning {
    background: #fffbeb;
    border-color: #fde68a;
    color: #92400e;
}

.auth-alert--info {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: #1d4ed8;
}

.auth-alert--success {
    background: #ecfdf5;
    border-color: #a7f3d0;
    color: #065f46;
}

.auth-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.authincation .login-form .mb-1 {
    display: inline-block;
    margin: 0 0 0.45rem;
    color: #334155;
    font-weight: 600;
}

.authincation .login-form .text-danger {
    color: #dc2626;
}

.auth-input-wrap {
    position: relative;
}

.auth-input-icon {
    position: absolute;
    left: 0.8rem;
    top: 50%;
    width: 1rem;
    height: 1rem;
    transform: translateY(-50%);
    color: #94a3b8;
    pointer-events: none;
}

.auth-input-icon svg {
    display: block;
    width: 1rem;
    height: 1rem;
}

.authincation .login-form .form-control {
    width: 100%;
    border-radius: 9px;
    border: 1px solid #cbd5e1;
    background: #ffffff;
    color: #0f172a;
    padding: 0.74rem 0.85rem 0.74rem 2.4rem;
    font-size: 0.95rem;
}

.authincation .login-form .form-control:focus {
    outline: 2px solid rgba(73, 17, 216, 0.2);
    outline-offset: 1px;
    border-color: #4911d8;
}

.authincation .auth-forgot-link {
    color: #4911d8;
    font-size: 0.84rem;
    font-weight: 600;
    text-decoration: none;
}

.authincation .auth-forgot-link:hover {
    color: #3b0eb3;
    text-decoration: underline;
}

.auth-input-wrap--password .form-control {
    padding-right: 8.5rem;
}

.authincation .auth-password-toggle {
    position: absolute;
    right: 0.68rem;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    min-height: 2.25rem;
    border-radius: 0.7rem;
    padding: 0.28rem 0.52rem;
    background: transparent;
    color: #64748b;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: color 0.18s var(--motion-standard), background-color 0.18s var(--motion-standard);
}

.authincation .auth-password-toggle:hover {
    color: #334155;
    background: rgba(148, 163, 184, 0.12);
}

.authincation .auth-password-toggle:focus-visible {
    background: rgba(73, 17, 216, 0.14);
}

.authincation .auth-login-meta {
    align-items: center;
}

.auth-security-note {
    margin-bottom: 0.85rem;
    color: #64748b;
    font-size: 0.78rem;
    line-height: 1.35;
    text-align: right;
}

.authincation .form-check {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.authincation .form-check-input {
    width: 0.95rem;
    height: 0.95rem;
    margin: 0;
}

.authincation .form-check-label {
    margin: 0;
    color: #334155;
    font-size: 0.9rem;
    font-weight: 600;
}

.authincation .login-form .btn-primary {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    border: 0;
    border-radius: 9px;
    background: #4911d8;
    color: #ffffff;
    font-size: 0.95rem;
    font-weight: 600;
    padding: 0.74rem 0.85rem;
    box-shadow: 0 10px 22px rgba(73, 17, 216, 0.24);
    transition: transform 0.16s var(--motion-standard), background-color 0.2s var(--motion-standard), box-shadow 0.2s var(--motion-standard), opacity 0.18s var(--motion-standard);
}

.authincation .login-form .btn-primary:hover {
    background: #3b0eb3;
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(73, 17, 216, 0.26);
}

.authincation .login-form .btn-primary:focus-visible {
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.18), 0 0 0 6px rgba(73, 17, 216, 0.34), 0 10px 22px rgba(73, 17, 216, 0.24);
}

.authincation .login-form .btn-primary:disabled {
    box-shadow: none;
    cursor: not-allowed;
    opacity: 0.72;
}

.auth-inline-spinner {
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.45);
    border-top-color: #ffffff;
    display: inline-block;
    margin-right: 0.45rem;
    animation: auth-spin 0.9s linear infinite;
}

.authincation .auth-template-meta {
    margin: 0.4rem 0 0;
    color: #64748b;
    font-size: 0.78rem;
    line-height: 1.4;
}

@media (max-width: 1024px) {
    .authincation .row {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .authincation .pages-left {
        min-height: 280px;
        padding: 1.65rem;
    }

    .auth-brand-title {
        font-size: 1.65rem;
    }
}

@media (max-width: 640px) {
    .authincation {
        padding: 0.75rem;
    }

    .auth-form-column {
        padding: 1rem;
    }

    .authincation .login-form {
        border-radius: 12px;
        padding: 1.3rem;
    }

    .authincation .login-form .title {
        font-size: 1.6rem;
    }

    .auth-label-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.2rem;
    }

    .authincation .auth-login-meta {
        display: grid;
        justify-content: stretch;
    }

    .auth-security-note {
        margin-bottom: 0.7rem;
        text-align: left;
    }
}

.cert-screen.shell {
    width: min(1280px, 94vw);
}

.cert-screen.shell.card {
    background: transparent;
    border: 0;
    box-shadow: none;
}

.cert-screen.panel {
    padding: 0;
}

.cert-screen {
    gap: 1rem;
}

.cert-screen__header {
    margin-bottom: 0.2rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.cert-screen--clean {
    gap: 0.75rem;
}

.cert-screen__canvas {
    min-height: 420px;
    display: flex;
    align-items: flex-start;
}

.cert-screen__eyebrow {
    margin: 0 0 0.4rem;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
    font-weight: 700;
}

.cert-screen__grid {
    display: grid;
    grid-template-columns: minmax(320px, 25%) minmax(0, 75%);
    gap: 1.1rem;
}

.cert-screen__sidebar {
    align-content: start;
}

.cert-card {
    padding: 1.1rem;
}

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

.cert-card__header h2 {
    margin: 0 0 0.35rem;
}

.cert-card__header--tight {
    margin-bottom: 0.7rem;
}

.cert-active-actions {
    margin-top: 1rem;
}

.cert-active-delete-form {
    width: 100%;
}

.cert-action-btn {
    width: 100%;
    border-radius: 12px;
    padding: 0.86rem 1rem;
    font-size: 1.02rem;
    font-weight: 700;
}

.cert-action-btn--danger {
    border: 1px solid rgba(248, 113, 113, 0.38);
    background: rgba(127, 29, 29, 0.16);
    color: #fecaca;
}

.cert-action-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.62);
    background: rgba(127, 29, 29, 0.32);
    color: #fee2e2;
}

.cert-active-note {
    margin-top: 0.85rem;
}

.cert-active-preview {
    margin-bottom: 1rem;
    border: 1px dashed #42506a;
    border-radius: 14px;
    background: #1b202b;
    min-height: 168px;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.45rem;
}

.cert-active-preview__icon {
    color: #4f36ff;
    font-size: 3.05rem;
    line-height: 1;
}

.cert-active-preview__name {
    margin: 0.2rem 0 0;
    font-size: 2rem;
    font-weight: 700;
    color: #f1f5f9;
    line-height: 1.15;
    word-break: break-word;
}

.cert-active-preview__expiry {
    margin: 0;
    color: #8f98a8;
    font-size: 1.45rem;
    font-weight: 500;
}

.cert-active-meta {
    display: grid;
    gap: 0.52rem;
}

.cert-active-meta__row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.8rem;
    font-size: 1.18rem;
}

.cert-active-meta__row > span {
    color: #8f98a8;
}

.cert-active-meta__row > strong {
    margin: 0;
    font-weight: 600;
    color: #e7edf9;
    text-align: right;
    word-break: break-word;
}

.cert-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 56px;
    height: 36px;
    padding: 0 0.7rem;
    border-radius: 10px;
    border: 1px solid rgba(15, 118, 110, 0.25);
    background: rgba(15, 118, 110, 0.08);
    color: #0f766e;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.cert-dropzone {
    position: relative;
    border: 2px dashed #465272;
    border-radius: 12px;
    background: #151a26;
    overflow: hidden;
    cursor: pointer;
}

.cert-dropzone__input {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    overflow: hidden;
    pointer-events: none;
}

.cert-dropzone__label {
    min-height: 132px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    text-align: center;
    padding: 1rem;
    color: #9aa4b2;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.cert-dropzone__icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(148, 163, 184, 0.18);
    color: #b8bfcb;
    font-size: 1.2rem;
}

.cert-dropzone__text {
    font-size: 1.02rem;
    line-height: 1.2;
    color: #8f98a8;
}

.cert-dropzone__text strong {
    color: #4f36ff;
}

.cert-dropzone__hint {
    font-size: 0.78rem;
    color: #7f8796;
}

.cert-dropzone__filename {
    font-size: 0.78rem;
    color: #c9d1de;
    font-weight: 600;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cert-dropzone:hover,
.cert-dropzone:focus-within,
.cert-dropzone:focus-visible,
.cert-dropzone.is-dragover {
    border-color: var(--primary);
    outline: none;
}

.cert-dropzone:hover .cert-dropzone__label,
.cert-dropzone:focus-within .cert-dropzone__label,
.cert-dropzone:focus-visible .cert-dropzone__label,
.cert-dropzone.is-dragover .cert-dropzone__label {
    background: rgba(var(--primary-rgb), 0.04);
}

.cert-upload-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 0.7fr);
    gap: 1rem;
    align-items: end;
}

.cert-field-actions {
    gap: 0.8rem;
}

.cert-alert {
    border-radius: 12px;
    padding: 0.8rem 0.95rem;
    font-size: 0.9rem;
    border: 1px solid transparent;
}

.cert-alert ul {
    margin: 0.5rem 0 0 1rem;
    padding: 0;
}

.cert-alert--success {
    background: #dcfce7;
    border-color: #86efac;
    color: #166534;
}

.cert-alert--danger {
    background: #fee2e2;
    border-color: #fca5a5;
    color: #991b1b;
}

.cert-table-wrap {
    overflow-x: auto;
}

.cert-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.cert-table th,
.cert-table td {
    padding: 0.7rem;
    text-align: left;
    border-bottom: 1px solid #e2e8f0;
    white-space: nowrap;
}

.cert-table th {
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748b;
}

.cert-table__title {
    margin: 0;
    font-weight: 700;
    color: #0f172a;
}

.cert-table__meta {
    margin-top: 0.2rem;
    font-size: 0.78rem;
}

.cert-table__action {
    color: #475569;
}

.cert-installed-card__empty {
    margin: 0;
}

.cert-installed-list {
    display: grid;
    gap: 0.72rem;
    max-height: 420px;
    overflow: auto;
    padding-right: 0.2rem;
}

.cert-card--installed-mode .cert-installed-list {
    max-height: 560px;
}

.cert-installed-item {
    border: 1px solid #313848;
    border-radius: 12px;
    background: #1a1f2b;
    padding: 0.8rem 0.9rem;
    display: grid;
    gap: 0.58rem;
}

.cert-installed-item--success {
    border-color: rgba(54, 193, 133, 0.34);
}

.cert-installed-item--danger {
    border-color: rgba(255, 102, 102, 0.32);
}

.cert-installed-item__top {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 0.72rem;
}

.cert-installed-item__title-wrap {
    display: flex;
    align-items: center;
    gap: 0.52rem;
    min-width: 0;
}

.cert-installed-item__icon {
    color: #6f7a90;
    font-size: 1.25rem;
    line-height: 1;
}

.cert-installed-item__title {
    margin: 0;
    font-size: 1.03rem;
    font-weight: 700;
    color: #d7dce7;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cert-installed-item__meta {
    margin: 0;
    color: #8f98a8;
    font-size: 0.95rem;
}

.cert-installed-item__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.cert-installed-item__runtime-note {
    font-size: 0.84rem;
    font-weight: 600;
    color: #7dd3a6;
}

.cert-installed-btn {
    min-width: 88px;
    border-radius: 10px;
    padding: 0.42rem 0.75rem;
    font-size: 0.84rem;
    font-weight: 700;
}

.cert-installed-btn--primary {
    border: 1px solid rgba(var(--primary-rgb), 0.5);
    background: rgba(var(--primary-rgb), 0.2);
    color: #d4b8ff;
}

.cert-installed-btn--primary:hover {
    border-color: rgba(var(--primary-rgb), 0.65);
    background: rgba(var(--primary-rgb), 0.32);
    color: #dbeafe;
}

.cert-installed-btn--danger {
    border: 1px solid rgba(248, 113, 113, 0.4);
    background: rgba(127, 29, 29, 0.18);
    color: #fecaca;
}

.cert-installed-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.6);
    background: rgba(127, 29, 29, 0.32);
    color: #fee2e2;
}

.cert-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.2rem 0.6rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid transparent;
}

.cert-badge--success {
    background: #dcfce7;
    color: #166534;
    border-color: #86efac;
}

.cert-badge--danger {
    background: #fee2e2;
    color: #991b1b;
    border-color: #fca5a5;
}

.cert-badge--warning {
    background: #fef3c7;
    color: #92400e;
    border-color: #fcd34d;
}

.cert-badge--neutral {
    background: #f1f5f9;
    color: #334155;
    border-color: #cbd5e1;
}

.cert-env-card {
    color: #dbeafe;
    border: 0;
    background: linear-gradient(145deg, #0f766e, #1d4ed8);
}

.cert-env-card h2 {
    margin: 0;
    color: #fff;
    font-size: 1.4rem;
}

.cert-env-card__row {
    display: flex;
    justify-content: space-between;
    gap: 0.6rem;
    align-items: center;
}

.cert-env-card__label {
    margin: 0 0 0.4rem;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(219, 234, 254, 0.84);
}

.cert-env-card__runtime-label {
    margin: 0 0 0.45rem;
    font-size: 0.78rem;
    color: rgba(219, 234, 254, 0.84);
}

.cert-env-card__hint {
    margin: 0.75rem 0 0;
    color: rgba(219, 234, 254, 0.92);
    font-size: 0.86rem;
}

.cert-env-card__warning {
    margin: 0.8rem 0 0;
    padding: 0.55rem 0.65rem;
    border-radius: 10px;
    background: rgba(127, 29, 29, 0.32);
    color: #fee2e2;
    font-size: 0.84rem;
}

.cert-plan__updated {
    font-size: 0.82rem;
}

.cert-canary__list {
    display: grid;
    gap: 0.7rem;
    max-height: 680px;
    overflow: auto;
    padding-right: 0.2rem;
}

.cert-canary__item {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 0.7rem;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.cert-canary__row {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
    align-items: center;
}

.cert-canary__title {
    margin: 0.45rem 0 0.25rem;
    font-weight: 700;
    color: #0f172a;
    font-size: 0.9rem;
}

.cert-inline-error {
    margin: 0.5rem 0;
    color: #991b1b;
    background: #fee2e2;
    border: 1px solid #fca5a5;
    border-radius: 8px;
    font-size: 0.82rem;
    padding: 0.4rem 0.55rem;
}

.cert-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1050;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    background: rgba(9, 11, 18, 0.68);
    backdrop-filter: blur(2px);
}

.cert-modal {
    width: min(640px, 94vw);
}

.cert-modal .section {
    margin: 0;
}

@media (max-width: 1100px) {
    .cert-screen__grid {
        grid-template-columns: 1fr;
    }

    .cert-upload-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .sri-env-switch {
        width: auto;
        justify-content: flex-start;
    }

    .sri-env-switch__icon {
        width: 34px;
        min-height: 30px;
    }

    .sri-env-switch__option {
        min-width: 76px;
        padding-inline: 0.64rem;
        font-size: 0.77rem;
    }

    .cert-screen.shell {
        width: min(1280px, 96vw);
    }

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

    .cert-installed-item__actions {
        justify-content: flex-start;
    }
}

.sri-config-screen.shell {
    width: min(1100px, 95vw);
}

body.admin-shell .sri-config-screen.shell.card {
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.admin-shell .sri-config-screen.panel {
    padding: 0;
}

.sri-config-screen__header {
    align-items: flex-start;
    margin-bottom: 1rem;
}

.sri-config-screen__actions {
    margin: 0;
}

.sri-config-screen__eyebrow {
    margin: 0 0 0.15rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 700;
    color: #8f96a8;
}

.sri-config-alert {
    border-radius: 12px;
    border: 1px solid transparent;
    padding: 0.9rem 1rem;
}

.sri-config-alert strong {
    display: block;
    margin: 0 0 0.2rem;
    font-size: 0.92rem;
}

.sri-config-alert p,
.sri-config-alert ul {
    margin: 0;
}

.sri-config-alert ul {
    padding-left: 1.15rem;
}

.sri-config-alert--success {
    border-color: rgba(16, 185, 129, 0.4);
    background: rgba(6, 78, 59, 0.58);
    color: #d1fae5;
}

.sri-config-alert--danger {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(127, 29, 29, 0.55);
    color: #fee2e2;
}

.sri-config-card {
    border-radius: 12px;
}

.sri-config-card__header {
    margin-bottom: 1rem;
}

.sri-config-card__header h2 {
    margin: 0 0 0.2rem;
    font-size: 1.1rem;
}

.sri-config-card__header--tight {
    margin-bottom: 0.75rem;
}

.sri-config-emitters {
    padding: 0;
    overflow: hidden;
    border-color: #2e3443;
    background: linear-gradient(180deg, #1a1f27 0%, #151920 100%);
}

.sri-config-emitters__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.35rem 1rem;
    border-bottom: 1px solid #2e3443;
}

.sri-config-emitters__header h2 {
    margin: 0 0 0.2rem;
    font-size: 1.16rem;
}

.sri-config-emitters__add-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
}

.sri-config-emitters__empty {
    padding: 1.2rem 1.35rem 1.35rem;
}

.sri-config-emitter-tabs {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.95rem 1.35rem;
    border-bottom: 1px solid #2e3443;
    overflow-x: auto;
    scrollbar-width: thin;
}

.sri-config-emitter-tab {
    border: 1px solid #33405a;
    border-radius: 999px;
    background: #1c2230;
    color: #bec8db;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.38rem 0.72rem;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.sri-config-emitter-tab.is-active {
    border-color: rgba(var(--primary-rgb), 0.5);
    background: rgba(var(--primary-rgb), 0.28);
    color: #dbe8ff;
}

.sri-config-emitter-list {
    padding: 1rem 1.35rem 1.35rem;
}

.sri-config-emitter-card {
    display: none;
    border-radius: 12px;
    border: 1px solid #2f384d;
    background: #161d28;
    overflow: hidden;
}

.sri-config-emitter-card.is-active {
    display: block;
}

.sri-config-emitter-card__header {
    padding: 1rem 1.05rem 0.95rem;
    border-bottom: 1px solid #2f384d;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.9rem;
}

.sri-config-emitter-card__identity {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
}

.sri-config-emitter-card__icon {
    width: 2.3rem;
    height: 2.3rem;
    border-radius: 10px;
    border: 1px solid #384862;
    background: #202a3b;
    color: #9db6df;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.sri-config-emitter-card__identity h3 {
    margin: 0 0 0.32rem;
    font-size: 1.25rem;
    text-transform: uppercase;
    color: #eef2fb;
}

.sri-config-emitter-card__meta {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.sri-config-emitter-card__ruc {
    margin: 0;
    color: #8f9ab0;
    font-size: 0.86rem;
    font-weight: 600;
}

.sri-config-emitter-card__status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.16rem 0.58rem;
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    border: 1px solid transparent;
}

.sri-config-emitter-card__status.is-active {
    border-color: rgba(34, 197, 94, 0.45);
    color: #8cf0b0;
    background: rgba(22, 101, 52, 0.33);
}

.sri-config-emitter-card__status.is-pending {
    border-color: rgba(245, 158, 11, 0.45);
    color: #f8d58a;
    background: rgba(120, 74, 13, 0.35);
}

.sri-config-emitter-card__certificate {
    margin: 0.45rem 0 0;
    color: #8f9ab0;
    font-size: 0.83rem;
}

.sri-config-emitter-card__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.sri-config-emitter-card__action {
    width: 2rem;
    height: 2rem;
    border-radius: 8px;
    border: 1px solid #394866;
    background: #1c2534;
    color: #9fb3d7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.sri-config-emitter-card__action:hover {
    border-color: #4f6ea8;
    background: #25334a;
    color: #e4edff;
}

.sri-config-emitter-card__points {
    padding: 0.95rem 1.05rem 1.05rem;
}

.sri-config-emitter-card__points-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.sri-config-emitter-card__points-header h4 {
    margin: 0;
    text-transform: uppercase;
    font-size: 0.9rem;
    letter-spacing: 0.03em;
    color: #dbe4f7;
}

.sri-config-emitter-card__add-point {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.83rem;
    font-weight: 700;
    color: #6ca8ff;
}

.sri-config-emitter-card__add-point:hover {
    color: #9cc4ff;
}

.sri-config-point-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.sri-config-point-card {
    border-radius: 10px;
    border: 1px solid #2f394d;
    background: #1b2230;
    padding: 0.72rem 0.75rem;
}

.sri-config-point-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.55rem;
}

.sri-config-point-card__badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
    margin: 0 0 0.38rem;
}

.sri-config-point-card__code,
.sri-config-point-card__tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    padding: 0.16rem 0.38rem;
    font-size: 0.7rem;
    font-weight: 700;
}

.sri-config-point-card__code {
    background: rgba(var(--primary-rgb), 0.2);
    color: #c4a8ff;
    border: 1px solid rgba(var(--primary-rgb), 0.35);
}

.sri-config-point-card__tag {
    background: rgba(71, 85, 105, 0.34);
    border: 1px solid rgba(148, 163, 184, 0.35);
    color: #cfd7e8;
}

.sri-config-point-card__tag.is-inactive {
    background: rgba(127, 29, 29, 0.32);
    border-color: rgba(248, 113, 113, 0.45);
    color: #fecaca;
}

.sri-config-point-card__action {
    width: 1.85rem;
    height: 1.85rem;
    border-radius: 7px;
    border: 1px solid #3f5278;
    background: #1a2231;
    color: #a7bde6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.sri-config-point-card__action:hover {
    border-color: #5984d6;
    background: #22314b;
    color: #e6efff;
}

.sri-config-point-card__title {
    margin: 0;
    color: #e6ecf8;
    font-size: 1rem;
    font-weight: 600;
}

.sri-config-point-card__address {
    margin: 0.3rem 0 0;
    color: #8f9bb1;
    font-size: 0.82rem;
    line-height: 1.25;
}

.sri-config-inline-error {
    margin: 0.45rem 0 0;
    color: #fecaca;
    font-size: 0.82rem;
    font-weight: 600;
}

.sri-config-wizard {
    padding: 0;
    overflow: hidden;
    border-color: #2e3443;
    background: linear-gradient(180deg, #1a1f27 0%, #151920 100%);
}

.sri-config-stepper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.9rem;
    padding: 1.35rem 1.4rem;
    border-bottom: 1px solid #2e3443;
    background: #222935;
}

.sri-config-step {
    border: 0;
    outline: none;
    padding: 0;
    background: transparent;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: #9ca3af;
    font-size: 1.12rem;
    font-weight: 700;
    line-height: 1.1;
    cursor: pointer;
    transition: color 0.2s ease;
}

.sri-config-step.is-disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.sri-config-step__dot {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(148, 163, 184, 0.35);
    background: rgba(30, 41, 59, 0.75);
    color: #9ca3af;
    font-size: 0.98rem;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.sri-config-step__label {
    line-height: 1;
    color: #d8dce6;
    font-size: 1.04rem;
    font-weight: 600;
}

.sri-config-step.is-active {
    color: #edf3ff;
}

.sri-config-step.is-active .sri-config-step__dot {
    border-color: rgba(var(--primary-rgb), 0.55);
    background: linear-gradient(135deg, #3b0eb3 0%, #4911D8 100%);
    color: #f8fbff;
    box-shadow: 0 0 0 6px rgba(var(--primary-rgb), 0.16);
}

.sri-config-step.is-active .sri-config-step__label {
    color: #f8fbff;
}

.sri-config-step__line {
    flex: 0 1 170px;
    height: 2px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.24);
}

.sri-config-step-panel {
    display: none;
    padding: 1.45rem 1.5rem 1.65rem;
}

.sri-config-step-panel.is-active {
    display: block;
}

.sri-config-form {
    gap: 1.1rem;
}

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

.sri-config-form-grid > .field {
    align-self: start;
}

.sri-config-col-full {
    grid-column: 1 / -1;
}

.sri-config-control {
    position: relative;
}

.sri-config-control__icon {
    position: absolute;
    left: 0.9rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.05rem;
    color: #7f889c;
    font-size: 1.08rem;
    line-height: 1;
    text-align: center;
    pointer-events: none;
}

.admin-custom .sri-config-form .sri-config-control > input,
.admin-custom .sri-config-form .sri-config-control > select {
    padding-left: 3rem;
}

.admin-custom .sri-config-form .sri-config-control > select {
    padding-right: 2.1rem;
}

.admin-custom .sri-config-form .sri-config-input-wrap.sri-config-control > input {
    padding-left: 3.2rem;
}

.sri-config-input-wrap {
    position: relative;
}

.sri-config-input-wrap > input {
    padding-right: 5.3rem;
}

.sri-config-control.is-locked > input,
.sri-config-control > input[readonly],
.sri-config-control > input:disabled,
.sri-config-control > select:disabled {
    background: #1c2230;
    border-color: #364763;
    color: #b8c5de;
}

.sri-config-control.is-locked .sri-config-control__icon {
    color: #93a3bf;
}

.sri-config-ruc-status {
    position: absolute;
    right: 0.55rem;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 6px;
    border: 1px solid rgba(148, 163, 184, 0.32);
    background: rgba(30, 41, 59, 0.55);
    color: #b0b9c8;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 0.22rem 0.46rem;
    min-width: 56px;
    text-align: center;
}

.sri-config-ruc-status.is-valid {
    color: #21c17a;
    border-color: rgba(33, 193, 122, 0.42);
    background: rgba(21, 128, 61, 0.22);
}

.sri-config-ruc-status.is-error {
    color: #fca5a5;
    border-color: rgba(248, 113, 113, 0.5);
    background: rgba(127, 29, 29, 0.32);
}

.sri-config-logo-upload {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.sri-config-logo-preview {
    width: 88px;
    height: 88px;
    flex: 0 0 88px;
    border-radius: 999px;
    border: 2px dashed #4b5563;
    background: #111827;
    color: #64748b;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
}

.sri-config-logo-dropzone {
    width: 100%;
    position: relative;
}

.sri-config-logo-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.sri-config-logo-label {
    min-height: 84px;
    width: 100%;
    border-radius: 12px;
    border: 1px dashed #3b4354;
    background: #0f141d;
    color: #d6dbe6;
    padding: 0.95rem 1rem;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 0.2rem;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.sri-config-logo-label:hover,
.sri-config-logo-label:focus {
    border-color: rgba(59, 130, 246, 0.55);
    background: #111b2a;
}

.sri-config-logo-label__icon {
    color: #3b82f6;
    font-size: 1.35rem;
    line-height: 1;
}

.sri-config-logo-label__title {
    font-size: 1rem;
    font-weight: 600;
}

.sri-config-logo-label__hint {
    font-size: 0.8rem;
    color: #8f98aa;
}

.sri-config-logo-label__file {
    min-height: 1.1rem;
    font-size: 0.78rem;
    color: #d4d8e3;
    font-weight: 600;
}

.sri-config-actions {
    align-items: center;
    justify-content: space-between;
}

.sri-config-actions--end {
    justify-content: flex-end;
}

.sri-config-next-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
}

.sri-config-next-btn i {
    font-size: 1rem;
}

.sri-config-state-card {
    min-height: 98px;
}

.sri-config-empty,
.sri-config-blocked {
    text-align: center;
}

.sri-config-blocked {
    padding-block: 2.4rem;
}

.sri-config-blocked h2 {
    margin: 0.8rem 0 0.45rem;
}

.sri-config-blocked__icon {
    width: 4.4rem;
    height: 4.4rem;
    margin-inline: auto;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    border: 1px solid rgba(251, 191, 36, 0.45);
    background: rgba(120, 74, 13, 0.35);
    color: #facc15;
}

.sri-config-obligations {
    margin-top: 0.2rem;
    border-radius: 14px;
    border: 1px solid #2d3547;
    background: linear-gradient(180deg, #1b2230 0%, #171e2b 100%);
    padding: 1.15rem 1.2rem 1.1rem;
    display: grid;
    gap: 1rem;
}

.sri-config-obligations__header h3 {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.98rem;
    font-weight: 700;
    color: #e9edf7;
}

.sri-config-obligations__icon {
    width: 1.95rem;
    height: 1.95rem;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(57, 95, 166, 0.18);
    color: #6c8bd7;
    border: 1px solid rgba(91, 121, 191, 0.34);
    font-size: 1.08rem;
}

.sri-config-obligations__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem 2.2rem;
}

.sri-config-obligation-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
}

.sri-config-obligation-item__copy h4 {
    margin: 0;
    font-size: 0.92rem;
    color: #e6eaf4;
    font-weight: 700;
    line-height: 1.18;
}

.sri-config-obligation-item__copy p {
    margin: 0.28rem 0 0;
    font-size: 0.82rem;
    color: #8e98ac;
    line-height: 1.25;
}

.sri-config-switch {
    position: relative;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}

.sri-config-switch > input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.sri-config-switch__track {
    width: 68px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid #333f56;
    background: #141a25;
    box-shadow: inset 0 0 0 1px rgba(61, 88, 136, 0.15);
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    position: relative;
    display: inline-block;
}

.sri-config-switch__track::before {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #dce1eb;
    box-shadow: 0 3px 9px rgba(10, 12, 20, 0.42);
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.sri-config-switch > input:checked + .sri-config-switch__track {
    background: rgba(var(--primary-rgb), 0.22);
    border-color: rgba(var(--primary-rgb), 0.55);
}

.sri-config-switch > input:checked + .sri-config-switch__track::before {
    transform: translateX(34px);
    background: #f7faff;
}

.sri-config-switch > input:focus-visible + .sri-config-switch__track {
    box-shadow: inset 0 0 0 1px rgba(var(--primary-rgb), 0.35), 0 0 0 3px rgba(var(--primary-rgb), 0.22);
}

.sri-config-obligations__currency {
    margin-top: 0.25rem;
    border: 1px solid #2f394d;
    border-radius: 14px;
    background: #1a202d;
    padding: 0.95rem 1rem;
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.sri-config-obligations__currency-icon {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--primary-rgb), 0.45);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(var(--primary-rgb), 0.9);
    font-size: 1.38rem;
    background: rgba(var(--primary-rgb), 0.12);
}

.sri-config-obligations__currency p {
    margin: 0;
    color: #d8deea;
    font-size: 0.9rem;
    font-weight: 500;
}

.sri-config-obligations__currency strong {
    font-weight: 700;
    color: #f2f6ff;
}

@media (max-width: 1080px) {
    .sri-config-emitters__header {
        flex-wrap: wrap;
    }

    .sri-config-point-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sri-config-form-grid {
        grid-template-columns: 1fr;
    }

    .sri-config-obligations__grid {
        grid-template-columns: 1fr;
        gap: 1.15rem;
    }
}

@media (max-width: 760px) {
    .sri-config-screen.shell {
        width: min(1100px, 97vw);
    }

    .sri-config-emitters__header,
    .sri-config-emitter-tabs,
    .sri-config-emitter-list {
        padding-inline: 1rem;
    }

    .sri-config-emitters__add-btn {
        width: 100%;
        justify-content: center;
    }

    .sri-config-emitter-card__identity h3 {
        font-size: 1.08rem;
    }

    .sri-config-emitter-card__header {
        flex-wrap: wrap;
    }

    .sri-config-emitter-card__actions {
        width: 100%;
        justify-content: flex-end;
    }

    .sri-config-emitter-card__points-header {
        flex-wrap: wrap;
    }

    .sri-config-point-grid {
        grid-template-columns: 1fr;
    }

    .sri-config-screen__header {
        flex-direction: column;
        gap: 0.75rem;
    }

    .sri-config-stepper {
        flex-wrap: wrap;
        justify-content: flex-start;
        padding: 1rem;
    }

    .sri-config-step__line {
        width: 100%;
        flex-basis: 100%;
    }

    .sri-config-step {
        font-size: 1rem;
    }

    .sri-config-step__dot {
        width: 2rem;
        height: 2rem;
        font-size: 0.88rem;
    }

    .sri-config-step__label {
        font-size: 0.92rem;
    }

    .sri-config-step-panel {
        padding: 1.15rem 1rem 1.2rem;
    }

    .sri-config-logo-upload {
        flex-direction: column;
        align-items: stretch;
    }

    .sri-config-logo-preview {
        margin: 0 auto;
    }

    .sri-config-obligations {
        padding: 1rem 0.95rem;
    }

    .sri-config-obligations__header h3 {
        font-size: 0.95rem;
    }

    .sri-config-obligation-item__copy h4 {
        font-size: 0.9rem;
    }

    .sri-config-obligation-item__copy p {
        font-size: 0.8rem;
    }

    .sri-config-switch__track {
        width: 62px;
        height: 32px;
    }

    .sri-config-switch__track::before {
        top: 4px;
        left: 4px;
        width: 22px;
        height: 22px;
    }

    .sri-config-switch > input:checked + .sri-config-switch__track::before {
        transform: translateX(30px);
    }

    .sri-config-obligations__currency p {
        font-size: 0.88rem;
    }
}

.s07-screen.shell {
    width: min(1320px, 96vw);
}

body.admin-shell .s07-screen.shell.card {
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.admin-shell .s07-screen.panel {
    padding: 0;
}

.s07-screen__header {
    align-items: flex-start;
    margin-bottom: 1rem;
}

.s07-screen__eyebrow {
    margin: 0 0 0.15rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 700;
    color: #8f96a8;
}

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

.s07-kpi-card h2 {
    margin: 0.35rem 0 0.6rem;
    font-size: clamp(1.4rem, 2.2vw, 2rem);
    color: #f1f5ff;
}

.s07-filters-card {
    border-radius: 12px;
}

.s07-filters-form {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.85rem;
    align-items: end;
}

.s07-filters-actions {
    justify-content: flex-end;
}

.s07-screen .btn-xs {
    padding: 0.38rem 0.62rem;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: 8px;
    width: auto;
    height: auto;
    min-width: 0;
    min-height: 0;
}

.s07-screen .btn.is-disabled {
    opacity: 0.58;
    cursor: not-allowed;
}

.s07-table-card {
    position: relative;
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}

.s07-table-card__header,
.s07-table-card__footer {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.s07-table-card__header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.s07-table-card__header h2 {
    margin: 0;
    font-size: 1.06rem;
}

.s07-table-card__footer {
    border-top: 1px solid #2f394d;
}

.s07-table-card__skeleton {
    position: absolute;
    top: 3.3rem;
    right: 0.72rem;
    bottom: 0.72rem;
    left: 0.72rem;
    display: none;
    gap: 0.58rem;
    pointer-events: none;
    z-index: 3;
    grid-template-columns: minmax(0, 1fr);
    align-content: start;
}

.s07-table-card__skeleton-head,
.s07-table-card__skeleton-row {
    display: grid;
    grid-template-columns: minmax(0, 2.3fr) minmax(0, 1.2fr) minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, 0.9fr);
    gap: 0.9rem;
    align-items: center;
}

.s07-table-card__skeleton-head {
    padding: 0 0.9rem;
    min-height: 1.2rem;
}

.s07-table-card__skeleton-row {
    border-radius: 11px;
    border: 1px solid rgba(66, 79, 105, 0.45);
    background: rgba(22, 30, 44, 0.88);
    padding: 0.9rem;
    min-height: 4.1rem;
}

.s07-table-card__skeleton-head > span,
.s07-table-card__skeleton-row > span {
    display: block;
    border-radius: 8px;
    height: 0.88rem;
    background: linear-gradient(100deg, rgba(46, 57, 80, 0.35) 18%, rgba(95, 112, 143, 0.52) 38%, rgba(46, 57, 80, 0.35) 58%);
    background-size: 220% 100%;
    animation: s07-shimmer 1.25s linear infinite;
}

.s07-table-card__skeleton-head > span {
    height: 0.72rem;
    opacity: 0.72;
}

.s07-table-card__skeleton-row > .is-patient {
    width: 84%;
}

.s07-table-card__skeleton-row > .is-status {
    width: 70%;
}

.s07-table-card__skeleton-row > .is-emission {
    width: 68%;
}

.s07-table-card__skeleton-row > .is-amount {
    width: 58%;
}

.s07-table-card__skeleton-row > .is-actions {
    width: 72%;
    justify-self: end;
}

.s07-table-card__skeleton-head > .is-actions {
    width: 54%;
    justify-self: end;
}

.s07-table-card__skeleton-head > .is-patient {
    width: 42%;
}

.s07-table-card__skeleton-head > .is-status,
.s07-table-card__skeleton-head > .is-emission {
    width: 46%;
}

.s07-table-card__skeleton-head > .is-amount {
    width: 44%;
}

.s07-table-card.is-loading .s07-table-card__skeleton {
    display: grid;
}

.s07-table-card.is-loading .s07-table-wrap,
.s07-table-card.is-loading .s07-empty-state,
.s07-table-card.is-loading .s07-table-card__footer {
    visibility: hidden;
    pointer-events: none;
}

@media (max-width: 991.98px) {
    .s07-table-card__skeleton-head,
    .s07-table-card__skeleton-row {
        grid-template-columns: minmax(0, 2fr) minmax(0, 1.2fr) minmax(0, 1.1fr) minmax(0, 0.9fr) minmax(0, 0.8fr);
    }
}

@media (max-width: 767.98px) {
    .s07-table-card__skeleton {
        left: 0.55rem;
        right: 0.55rem;
    }

    .s07-table-card__skeleton-head,
    .s07-table-card__skeleton-row {
        grid-template-columns: minmax(0, 1.7fr) minmax(0, 1fr) minmax(0, 0.9fr);
        gap: 0.58rem;
    }

    .s07-table-card__skeleton-head > .is-emission,
    .s07-table-card__skeleton-head > .is-actions,
    .s07-table-card__skeleton-row > .is-emission,
    .s07-table-card__skeleton-row > .is-actions {
        display: none;
    }
}

@keyframes s07-shimmer {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}

.s07-table-wrap {
    overflow-x: auto;
}

.s07-table-wrap:has(.is-menu-open) {
    overflow: visible;
}

.s07-unified-list {
    display: grid;
    gap: 0.72rem;
    padding: 0.85rem;
}

.s07-unified-row {
    border: 1px solid #2f394d;
    border-radius: 12px;
    background: #171f2c;
    overflow: hidden;
}

.s07-unified-row.is-row-error {
    border-color: rgba(248, 113, 113, 0.5);
    box-shadow: inset 0 0 0 1px rgba(153, 27, 27, 0.2);
}

.s07-unified-row > summary {
    list-style: none;
    cursor: pointer;
}

.s07-unified-row > summary::-webkit-details-marker {
    display: none;
}

.s07-unified-row__summary {
    display: grid;
    grid-template-columns: minmax(280px, 2.4fr) minmax(150px, 1.2fr) minmax(150px, 1fr) minmax(110px, 0.8fr) minmax(260px, 1.6fr);
    gap: 0.75rem;
    align-items: center;
    padding: 0.9rem 0.95rem;
    transition: background-color 0.2s ease;
}

.s07-unified-row__summary:hover {
    background: #1c2635;
}

.s07-unified-row[open] .s07-unified-row__summary {
    border-bottom: 1px solid #2f394d;
    background: #1a2432;
}

.s07-unified-row__patient {
    display: flex;
    align-items: center;
    gap: 0.62rem;
    min-width: 0;
}

.s07-unified-row__patient-copy {
    min-width: 0;
}

.s07-unified-row__patient-line {
    display: flex;
    align-items: center;
    gap: 0.42rem;
    flex-wrap: wrap;
}

.s07-unified-row__patient-line strong,
.s07-unified-row__patient-line a {
    font-size: 0.88rem;
}

.s07-unified-row__patient-copy small {
    display: block;
    margin-top: 0.18rem;
    color: #9aa6bf;
    font-size: 0.74rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-unified-alias {
    border-radius: 999px;
    border: 1px solid rgba(96, 165, 250, 0.44);
    background: rgba(30, 64, 175, 0.22);
    color: #bfdbfe;
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.16rem 0.5rem;
}

.s07-unified-row__status,
.s07-unified-row__emission,
.s07-unified-row__amount {
    display: grid;
    gap: 0.2rem;
}

.s07-unified-row__status small,
.s07-unified-row__emission small,
.s07-unified-row__amount small {
    color: #9aa6bf;
    font-size: 0.74rem;
}

.s07-unified-row__status small,
.s07-unified-row__amount strong {
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
}

.s07-unified-row__amount strong {
    color: #edf4ff;
    font-size: 0.94rem;
}

.s07-unified-row__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 0.34rem;
}

.s07-unified-row__actions form {
    margin: 0;
}

.s07-unified-row__details {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
    padding: 0.9rem 0.95rem;
    background: #141b27;
}

.s07-unified-card {
    border: 1px solid #2d374b;
    border-radius: 10px;
    background: #1a2231;
    padding: 0.75rem 0.8rem;
}

.s07-unified-card header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.55rem;
}

.s07-unified-card header h3 {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 700;
    color: #e2e9f7;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.s07-unified-card__edit {
    color: #93c5fd;
    font-size: 0.72rem;
    font-weight: 600;
    text-decoration: none;
}

.s07-unified-card__edit:hover {
    color: #bfdbfe;
}

.s07-unified-card dl {
    margin: 0;
    display: grid;
    gap: 0.38rem;
}

.s07-unified-card dl > div {
    display: grid;
    gap: 0.1rem;
}

.s07-unified-card dt {
    margin: 0;
    color: #8e9ab1;
    font-size: 0.69rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.s07-unified-card dd {
    margin: 0;
    color: #e6edf9;
    font-size: 0.79rem;
    line-height: 1.3;
}

.s07-unified-card dd.is-mono {
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
    word-break: break-all;
}

.s07-unified-doc-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.s07-unified-doc-note {
    margin: 0.55rem 0 0;
    color: #9aa6bf;
    font-size: 0.74rem;
}

.s07-table {
    width: 100%;
    border-collapse: collapse;
}

.s07-table th,
.s07-table td {
    padding: 0.92rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    vertical-align: top;
    text-align: left;
    font-size: 0.86rem;
}

.s07-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #b4bfd5;
    background: #171617;
}

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

.s07-table tbody tr:hover td {
    background: rgba(var(--primary-rgb), 0.07);
}

.s07-table td strong {
    display: block;
    color: #eef2fb;
    font-size: 0.88rem;
}

.s07-table td small {
    display: block;
    margin-top: 0.12rem;
    color: #8f9bb1;
    font-size: 0.74rem;
}

.s07-table .is-right {
    text-align: right;
}

.s07-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.s07-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.33rem;
    white-space: nowrap;
}

.s07-action-btn i {
    font-size: 0.92rem;
    line-height: 1;
}

.s07-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.2rem 0.62rem;
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.s07-unified-status-pill {
    width: fit-content;
    max-width: 100%;
    justify-self: start;
    justify-content: flex-start;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.s07-unified-status-pill__icon {
    font-size: 0.84rem;
    line-height: 1;
}

.s07-pill--success {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s07-pill--warning {
    border-color: rgba(252, 211, 77, 0.46);
    color: #fcd34d;
    background: rgba(120, 74, 13, 0.36);
}

.s07-pill--danger {
    border-color: rgba(248, 113, 113, 0.48);
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.s07-pill--info {
    border-color: rgba(var(--primary-rgb), 0.45);
    color: #c4b5fd;
    background: rgba(var(--primary-rgb), 0.18);
}

.s07-profile-count {
    color: #b9c6de;
    font-size: 0.8rem;
    font-weight: 600;
}

.s07-empty-state {
    min-height: 180px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1.5rem 1.2rem;
}

.s07-empty-state h3 {
    margin: 0.4rem 0 0.2rem;
    color: #edf2fc;
}

.s07-state-card {
    min-height: 120px;
}

.s07-kpi-card {
    position: relative;
}

.s07-kpi-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.s07-kpi-card__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
}

.s07-kpi-card__icon--warning {
    color: #fbbf24;
    background: rgba(251, 191, 36, 0.12);
}

.s07-kpi-card__icon--info {
    color: #60a5fa;
    background: rgba(96, 165, 250, 0.12);
}

.s07-kpi-card__icon--danger {
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
}

.s07-kpi-card__icon--success {
    color: #34d399;
    background: rgba(52, 211, 153, 0.12);
}

.s07-toolbar-card {
    border-radius: 14px;
    padding: 0.95rem 1rem 1rem;
}

.s07-toolbar-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.8rem;
}

.s07-toolbar-card__title h2 {
    margin: 0;
    font-size: 1.35rem;
    letter-spacing: -0.01em;
}

.s07-sync-indicator {
    margin: 0.25rem 0 0;
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
}

.s07-sync-dot {
    width: 0.56rem;
    height: 0.56rem;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.18);
}

.s07-toolbar-card__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
}

.s07-toolbar-card__actions .btn {
    white-space: nowrap;
}

.s07-toolbar-card__actions .btn i {
    margin-right: 0.3rem;
}

.s07-page-size-form {
    margin: 0;
}

.s07-page-size-form select {
    border-radius: 10px;
    border: 1px solid #38445d;
    background: #1f2737;
    color: #d6e0f4;
    padding: 0.44rem 1.9rem 0.44rem 0.7rem;
    line-height: 1.2;
    font-size: 0.78rem;
    font-weight: 700;
    min-width: 6.1rem;
    min-height: 2.5rem;
}

.s07-compact-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: #c2cde3;
}

.s07-compact-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.s07-compact-toggle__slider {
    position: relative;
    width: 2.25rem;
    height: 1.25rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.35);
    border: 1px solid rgba(148, 163, 184, 0.4);
    transition: all 0.2s ease;
}

.s07-compact-toggle__slider::before {
    content: "";
    position: absolute;
    top: 1px;
    left: 1px;
    width: 0.96rem;
    height: 0.96rem;
    border-radius: 50%;
    background: #f8fafc;
    transition: transform 0.2s ease;
}

.s07-compact-toggle input:checked + .s07-compact-toggle__slider {
    background: rgba(71, 85, 105, 0.72);
    border-color: rgba(96, 165, 250, 0.48);
}

.s07-compact-toggle input:checked + .s07-compact-toggle__slider::before {
    transform: translateX(0.96rem);
}

.s07-filter-strip {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.s07-filter-strip--advanced {
    display: block;
}

.s07-filters-form--advanced {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    gap: 0.82rem;
    margin-bottom: 0;
}

.s07-filters-form--advanced > * {
    min-width: 0;
}

.s07-advanced-filter__top {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(210px, 0.55fr) auto;
    gap: 0.72rem;
    align-items: center;
    width: 100%;
}

.s07-advanced-filter__search .s07-smart-search {
    min-height: 3.18rem;
    border-radius: 12px;
    background: transparent;
    border-color: #313d54;
}

.s07-advanced-filter__search .s07-smart-search input[type="text"] {
    font-size: 0.9rem;
    background: transparent !important;
}

.s07-advanced-filter__search > i {
    top: 50%;
    transform: translateY(-50%);
}

.s07-advanced-filter__date {
    position: relative;
}

.s07-advanced-filter__date > i {
    position: absolute;
    left: 0.86rem;
    top: 50%;
    transform: translateY(-50%);
    color: #95a6c6;
    font-size: 0.95rem;
    pointer-events: none;
}

.admin-custom .s07-advanced-filter__date > input[type="text"] {
    height: 3.18rem;
    min-height: 3.18rem;
    border-radius: 12px;
    border: 1px solid #313d54;
    background: linear-gradient(180deg, #1c2433 0%, #1a2231 100%);
    color: #e4ecfb;
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.52rem 0.9rem 0.52rem 2.46rem;
}

.admin-custom .s07-advanced-filter__date > input[type="text"]::placeholder {
    color: #a1b1cd;
}

.s07-advanced-filter__toggle {
    width: auto;
    min-width: 0;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    min-height: 3.18rem;
    border-radius: 12px;
    padding: 0.52rem 1rem;
    border-color: #313d54;
    background: linear-gradient(180deg, #1e2737 0%, #1b2434 100%);
    color: #d9e3f7;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.s07-advanced-filter__toggle i {
    margin-right: 0.36rem;
    transition: transform 0.2s ease;
}

.s07-advanced-filter__toggle.is-open i {
    transform: rotate(180deg);
}

.s07-advanced-filter__panel {
    border-top: 1px solid #2d3648;
    padding-top: 0.86rem;
    animation: s07-advanced-filters-in 0.18s ease;
}

.s07-advanced-filter__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.78rem;
}

.s07-advanced-filter__grid .field {
    margin: 0;
}

.s07-advanced-filter__grid .field > label {
    margin: 0 0 0.42rem;
    color: #8896af;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.73rem;
    font-weight: 700;
}

.s07-advanced-filter__grid .field > select {
    height: 2.86rem;
    min-height: 2.86rem;
    border-radius: 11px;
    border: 1px solid #303b51;
    background: linear-gradient(180deg, #202939 0%, #1d2635 100%);
    color: #dde7fb;
    font-size: 0.95rem;
    font-weight: 600;
    padding: 0.5rem 1.95rem 0.5rem 0.92rem;
}

@keyframes s07-advanced-filters-in {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.s07-filters-form--demo {
    flex: 1;
    min-width: 0;
    grid-template-columns: minmax(220px, 1.6fr) repeat(3, minmax(150px, 1fr));
    margin-bottom: 0;
}

.s07-filters-form--demo .field {
    margin-bottom: 0;
}

.s07-filters-form--demo input,
.s07-filters-form--demo select {
    height: 2.5rem;
    min-height: 2.5rem;
    padding: 0.48rem 0.92rem;
    line-height: 1.2;
    border-radius: 10px;
    border: 1px solid #344158;
    background: #1d2534;
    color: #e5ecfb;
    font-size: 0.86rem;
    font-weight: 600;
}

.s07-filters-form--demo select {
    padding-right: 2rem;
}

.s07-filters-form--demo input::placeholder {
    color: #97a6c0;
}

.s07-filters-form--demo select option,
.s07-page-size-form select option {
    background: #1a2130;
    color: #e5ecfb;
}

.s07-search-control {
    position: relative;
}

.s07-search-control i {
    position: absolute;
    left: 0.78rem;
    top: 0.98rem;
    transform: none;
    color: #8ea0bf;
    font-size: 0.92rem;
    pointer-events: none;
    z-index: 2;
}

.admin-custom .s07-search-control > input[type="text"] {
    padding-left: 2.42rem;
    line-height: 1.2;
}

.s07-smart-search {
    min-height: 2.5rem;
    border-radius: 10px;
    border: 1px solid #344158;
    background: #1d2534;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.34rem;
    padding: 0.35rem 0.75rem 0.35rem 2.42rem;
}

.s07-smart-search:focus-within {
    border-color: #4f78d0;
    box-shadow: 0 0 0 1px rgba(79, 120, 208, 0.35);
}

.admin-custom .s07-search-control .s07-smart-search input[type="text"] {
    border: 0;
    background: transparent;
    height: auto;
    min-height: 1.4rem;
    padding: 0;
    box-shadow: none;
    flex: 1 1 120px;
    min-width: 120px;
    color: #e5ecfb;
    font-size: 0.86rem;
    font-weight: 600;
}

.admin-custom .s07-search-control .s07-smart-search input[type="text"]:focus {
    outline: none;
}

.admin-custom .s07-search-control .s07-smart-search input[type="text"]::placeholder {
    color: #97a6c0;
}

.s07-smart-search__chips {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.34rem;
}

.s07-smart-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--primary-rgb), 0.45);
    background: rgba(var(--primary-rgb), 0.16);
    color: #c4a8ff;
    padding: 0.18rem 0.5rem;
    line-height: 1;
    font-size: 0.79rem;
    font-weight: 700;
}

.s07-smart-tag__label {
    white-space: nowrap;
}

.s07-smart-tag__remove {
    border: 0;
    background: transparent;
    color: #8fc0ff;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: 0.95rem;
    font-weight: 700;
}

.s07-smart-tag__remove:hover {
    color: #dbe9ff;
}

.s07-smart-search__hint {
    margin: 0.3rem 0 0;
    color: #8ea0bf;
    font-size: 0.72rem;
    line-height: 1.2;
}

.s07-smart-search__hint code {
    color: #c7d7f5;
    background: rgba(24, 33, 48, 0.8);
    border: 1px solid #354968;
    border-radius: 5px;
    padding: 0.02rem 0.25rem;
}

.s07-status-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    flex-wrap: wrap;
    margin-left: auto;
}

.s07-status-tab {
    border: 1px solid #323d53;
    background: #232b3c;
    color: #9eabc2;
    border-radius: 8px;
    padding: 0.3rem 0.78rem;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-decoration: none;
}

.s07-status-tab:hover {
    color: #e4ebfb;
    border-color: #43557a;
}

.s07-status-tab.is-active {
    color: #f4f8ff;
    border-color: #4f46e5;
    background: #4f46e5;
}

.s07-table-card__header--meta {
    border-bottom: 1px solid #2f394d;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.s07-table--dense th,
.s07-table--dense td {
    font-size: 0.84rem;
}

.s07-table--dense th:nth-child(1),
.s07-table--dense td:nth-child(1) {
    min-width: 220px;
}

.s07-table--dense th:nth-child(6),
.s07-table--dense td:nth-child(6),
.s07-table--dense th:nth-child(7),
.s07-table--dense td:nth-child(7) {
    min-width: 145px;
}

.s07-table--dense th:last-child,
.s07-table--dense td:last-child {
    white-space: nowrap;
}

.s07-patient-cell {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.s07-patient-cell__details {
    display: grid;
    gap: 0.2rem;
}

.s07-patient-link {
    color: #dfe7fa;
    font-weight: 700;
    text-decoration: none;
}

.s07-patient-link:hover {
    color: #8ab4ff;
    text-decoration: underline;
}

.s07-patient-alias,
.s07-patient-alias-link {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    width: fit-content;
    font-size: 0.79rem;
    font-weight: 600;
    text-decoration: none;
}

.s07-patient-alias {
    color: #3b82f6;
}

.s07-patient-alias:hover {
    color: #60a5fa;
}

.s07-patient-alias-link {
    color: #8f9fbb;
    border: 1px dashed #4a5b77;
    border-radius: 7px;
    padding: 0.2rem 0.48rem;
    background: rgba(28, 37, 53, 0.65);
}

.s07-patient-alias-link:hover {
    color: #d9e2f4;
    border-color: #6a7fa5;
}

.s07-avatar {
    width: 1.8rem;
    height: 1.8rem;
    min-width: 1.8rem;
    min-height: 1.8rem;
    border-radius: 50%;
    aspect-ratio: 1 / 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 1.8rem;
    line-height: 1;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: #eef2ff;
    overflow: hidden;
}

.s07-avatar--violet {
    background: #7c3aed;
}

.s07-avatar--mint {
    background: #14b8a6;
}

.s07-avatar--orange {
    background: #f97316;
}

.s07-avatar--sky {
    background: #3b82f6;
}

.s07-avatar--rose {
    background: #ef4444;
}

.s07-avatar--indigo {
    background: #6366f1;
}

.s07-pill-dot {
    width: 0.36rem;
    height: 0.36rem;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.85;
}

.s07-amount {
    color: #f1f5ff;
    font-weight: 700;
}

.s07-data-action,
.s07-icon-action {
    width: 1.9rem;
    height: 1.9rem;
    border: 1px solid #364156;
    border-radius: 8px;
    color: #b8c5dd;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: #212a3a;
}

.s07-data-action:hover,
.s07-icon-action:hover {
    color: #ecf3ff;
    border-color: #4b6089;
}

.s07-data-action.is-danger,
.s07-icon-action.is-danger {
    border-color: rgba(248, 113, 113, 0.48);
    background: rgba(127, 29, 29, 0.28);
    color: #fecaca;
}

.s07-data-action.is-danger:hover,
.s07-icon-action.is-danger:hover {
    border-color: rgba(248, 113, 113, 0.72);
    background: rgba(127, 29, 29, 0.42);
    color: #fee2e2;
}

.s07-actions--dense {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    flex-wrap: nowrap;
}

.s07-action-btn--primary {
    min-width: 6.75rem;
    justify-content: center;
}

.s07-action-btn--danger {
    min-width: 6.75rem;
    justify-content: center;
    border: 1px solid rgba(248, 113, 113, 0.52);
    background: rgba(127, 29, 29, 0.32);
    color: #fecaca;
}

.s07-action-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.7);
    background: rgba(127, 29, 29, 0.46);
    color: #fee2e2;
}

.s07-table tbody tr.is-row-error td {
    background: rgba(127, 29, 29, 0.12);
}

.s07-table-wrap.is-compact .s07-table th,
.s07-table-wrap.is-compact .s07-table td {
    padding: 0.46rem 0.62rem;
}

.s07-table-wrap.is-compact .s07-table td small {
    font-size: 0.69rem;
}

.s07-table-wrap.is-compact .s07-unified-list {
    gap: 0.52rem;
    padding: 0.55rem;
}

.s07-table-wrap.is-compact .s07-unified-row__summary,
.s07-table-wrap.is-compact .s07-unified-row__details {
    padding: 0.62rem;
}

.s07-table-wrap.is-compact .s07-unified-card {
    padding: 0.6rem;
}

.s07-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.nx-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.nx-pagination__item {
    min-width: 3.2rem;
    height: 3.2rem;
    padding: 0 0.82rem;
    border-radius: 0.92rem;
    border: 1px solid #313a4c;
    background: #1c2433;
    color: #a8b3ca;
    text-decoration: none;
    font-size: 1.04rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: background-color 0.18s var(--motion-standard), border-color 0.18s var(--motion-standard), color 0.18s var(--motion-standard), box-shadow 0.18s var(--motion-standard), transform 0.16s var(--motion-standard);
}

.nx-pagination__item:hover {
    color: #dce5f8;
    border-color: #42506a;
    background: #222c3e;
}

.nx-pagination__item:focus-visible {
    transform: translateY(-1px);
}

.nx-pagination__item.is-active {
    color: #f8faff;
    border-color: #4f46e5;
    background: linear-gradient(140deg, #4f46e5 0%, #4338ca 100%);
    box-shadow: 0 10px 22px rgba(67, 56, 202, 0.38);
}

.nx-pagination__item.is-disabled {
    opacity: 0.48;
    pointer-events: none;
}

.nx-pagination__ellipsis {
    color: #6f7f9d;
    font-size: 1rem;
    padding: 0 0.12rem;
}

@media (max-width: 767.98px) {
    .nx-pagination {
        gap: 0.36rem;
    }

    .nx-pagination__item {
        min-width: 2.6rem;
        height: 2.6rem;
        border-radius: 0.78rem;
        font-size: 0.95rem;
        padding: 0 0.62rem;
    }
}

.s07-context-card {
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.s07-context-title {
    margin: 0.25rem 0 0.25rem;
    font-size: 1.2rem;
    color: #f1f5ff;
}

.s07-profiles-grid {
    grid-template-columns: minmax(320px, 0.9fr) minmax(420px, 1.1fr);
}

.s07-profiles-list,
.s07-profile-form-card,
.s07-preview-card,
.s07-summary-card {
    border-radius: 12px;
}

.s07-profiles-list__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    margin-bottom: 0.9rem;
}

.s07-profiles-list__header h2 {
    margin: 0;
    font-size: 1.04rem;
}

.s07-profile-list-wrap {
    display: grid;
    gap: 0.62rem;
}

.s07-profile-item {
    border: 1px solid #34415b;
    border-radius: 11px;
    background: #1b2231;
    padding: 0.75rem 0.82rem;
    display: grid;
    gap: 0.5rem;
}

.s07-profile-item.is-inactive {
    opacity: 0.72;
    border-color: #4f3648;
}

.s07-profile-item__main h3 {
    margin: 0;
    color: #eef2fb;
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.34rem;
}

.s07-profile-item__main p {
    margin: 0.25rem 0 0;
    color: #cfd8eb;
}

.s07-profile-item__main small {
    color: #8f9bb0;
    font-size: 0.78rem;
}

.s07-profile-item__actions {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.s07-profile-item__actions form {
    margin: 0;
}

.s07-profile-form {
    display: grid;
    gap: 0.8rem;
}

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

.s07-issue-selector {
    display: grid;
    gap: 0.2rem;
    min-width: min(320px, 100%);
}

.s07-issue-selector label {
    font-size: 0.76rem;
    color: #8e99ad;
}

.s07-issue-grid {
    grid-template-columns: minmax(520px, 1.2fr) minmax(280px, 0.8fr);
    align-items: start;
}

.s07-summary-card {
    display: grid;
    gap: 0.8rem;
    height: fit-content;
}

.s07-summary-card h2 {
    margin: 0;
    font-size: 1.04rem;
}

.s07-summary-block {
    border: 1px solid #33425c;
    border-radius: 10px;
    background: #1c2434;
    padding: 0.75rem 0.82rem;
}

.s07-summary-block h3 {
    margin: 0 0 0.38rem;
    font-size: 0.84rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #9eaac0;
}

.s07-summary-block p {
    margin: 0.2rem 0;
    color: #e4eaf8;
}

.s07-summary-block small {
    color: #8f9bb0;
}

.s07-summary-block--warning {
    border-color: rgba(245, 158, 11, 0.45);
    background: rgba(120, 74, 13, 0.35);
}

.s07-summary-total {
    font-size: 1.6rem;
    font-weight: 800;
    color: #f1f5ff;
}

.s07-emit-form {
    margin-top: 0.25rem;
}

.s07-emit-btn {
    width: 100%;
    justify-content: center;
}

.s07-issue-modal {
    position: fixed;
    inset: 0;
    z-index: 1230;
    pointer-events: none;
}

body.s07-issue-panel-open {
    overflow: hidden;
}

body.s07-document-panel-open {
    overflow: hidden;
}

body.s07-legacy-pdf-open {
    overflow: hidden;
}

body.s07-document-file-open {
    overflow: hidden;
}

body.s07-group-modal-open {
    overflow: hidden;
}

.s07-issue-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(3, 8, 18, 0.72);
    backdrop-filter: blur(2px);
    opacity: 0;
    transition: opacity 0.22s ease;
}

.s07-issue-modal__panel {
    position: relative;
    width: min(1200px, 95vw);
    max-height: calc(100vh - 3.2rem);
    margin: 1.6rem auto;
    border: 1px solid #2b354a;
    border-radius: 14px;
    background: linear-gradient(165deg, #161d2c 0%, #111827 100%);
    box-shadow: 0 32px 72px rgba(3, 8, 18, 0.62);
    transform: translateY(22px) scale(0.985);
    opacity: 0;
    transition: transform 0.25s ease, opacity 0.25s ease;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.s07-issue-modal__body {
    position: relative;
    overflow: auto;
    min-height: 280px;
}

.s07-panel-skeleton {
    display: grid;
    gap: 0.85rem;
    padding: 0.95rem;
}

.s07-panel-skeleton__card {
    border: 1px solid rgba(62, 76, 101, 0.54);
    border-radius: 12px;
    background: rgba(25, 33, 50, 0.82);
    padding: 0.9rem;
    display: grid;
    gap: 0.58rem;
}

.s07-panel-skeleton__line {
    display: block;
    height: 0.76rem;
    border-radius: 999px;
    width: 72%;
    background: linear-gradient(100deg, rgba(60, 75, 101, 0.38) 18%, rgba(111, 131, 166, 0.58) 38%, rgba(60, 75, 101, 0.38) 58%);
    background-size: 230% 100%;
    animation: s07-shimmer 1.2s linear infinite;
}

.s07-panel-skeleton__line.is-wide {
    width: 92%;
}

.s07-panel-skeleton__line.is-short {
    width: 48%;
}

.s07-issue-modal.is-open {
    pointer-events: auto;
}

.s07-issue-modal.is-open .s07-issue-modal__backdrop {
    opacity: 1;
}

.s07-issue-modal.is-open .s07-issue-modal__panel {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.s07-issue-modal.is-loading .s07-issue-modal__body {
    cursor: progress;
}

.s07-legacy-pdf-modal__panel {
    width: min(1320px, 96vw);
}

.s07-legacy-pdf-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid #2b354a;
    background: rgba(17, 24, 39, 0.9);
}

.s07-legacy-pdf-modal__header h2 {
    margin: 0;
    font-size: 1rem;
    color: #dbe8ff;
}

.s07-legacy-pdf-modal__body {
    height: calc(100vh - 8.2rem);
    min-height: 560px;
    background: #0f172a;
}

.s07-legacy-pdf-modal__iframe {
    width: 100%;
    height: 100%;
    border: 0;
    background: #0f172a;
}

.s07-document-file-modal__panel {
    width: min(1320px, 96vw);
}

.s07-issue-modal[data-s07-document-file-modal] {
    z-index: 1265;
}

.s07-document-file-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid #2b354a;
    background: rgba(17, 24, 39, 0.9);
}

.s07-document-file-modal__header h2 {
    margin: 0;
    font-size: 1rem;
    color: #dbe8ff;
}

.s07-document-file-modal__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.s07-document-file-modal__download {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    border: 1px solid rgba(96, 165, 250, 0.5);
    border-radius: 8px;
    padding: 0.38rem 0.62rem;
    color: #bfdbfe;
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: none;
    background: rgba(30, 64, 175, 0.24);
}

.s07-document-file-modal__download:hover {
    color: #dbeafe;
    border-color: rgba(147, 197, 253, 0.7);
    background: rgba(30, 64, 175, 0.36);
}

.s07-document-file-modal__body {
    height: calc(100vh - 8.2rem);
    min-height: 560px;
    background: #0f172a;
    position: relative;
}

.s07-document-file-modal__iframe {
    width: 100%;
    height: 100%;
    border: 0;
    background: #0f172a;
}

.s07-document-file-modal__xml {
    margin: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    padding: 1rem 1.15rem;
    background: #0f172a;
    color: #dbe8ff;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.78rem;
    line-height: 1.5;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.s07-document-file-modal__placeholder {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1rem 1.5rem;
    color: #b8c5dd;
    font-size: 0.86rem;
}

.s07-issue-alert {
    border-radius: 11px;
    border: 1px solid transparent;
    background: rgba(44, 63, 96, 0.28);
    color: #d7e5ff;
    padding: 0.75rem 0.85rem;
    display: grid;
    gap: 0.25rem;
    margin: 0.95rem;
}

.s07-issue-alert ul {
    margin: 0;
    padding-left: 1rem;
}

.s07-issue-alert--success {
    border-color: rgba(74, 222, 128, 0.4);
    background: rgba(22, 101, 52, 0.32);
    color: #bbf7d0;
}

.s07-issue-alert--danger {
    border-color: rgba(248, 113, 113, 0.46);
    background: rgba(127, 29, 29, 0.34);
    color: #fee2e2;
}

.s07-issue-empty {
    min-height: 360px;
    display: grid;
    place-content: center;
    gap: 0.45rem;
    text-align: center;
    padding: 2rem 1rem;
}

.s07-issue-empty h3 {
    margin: 0;
}

.s07-issue-popup-card__top {
    padding: 1rem 1.15rem;
    border-bottom: 1px solid #2b3547;
    background: #252d3c;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.9rem;
}

.s07-issue-popup-card__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    min-width: 0;
}

.s07-issue-popup-card__logo {
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 10px;
    border: 1px solid #3c4a66;
    background: #2b3446;
    color: #6d57ff;
    font-size: 1.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s07-issue-popup-card__brand h3 {
    margin: 0;
    color: #f2f6ff;
    font-size: 1.05rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-popup-card__brand p {
    margin: 0.08rem 0 0;
    color: #b9c3d9;
    font-size: 0.84rem;
}

.s07-issue-popup-card__meta {
    text-align: right;
}

.s07-issue-popup-card__meta small {
    display: block;
    color: #9eabc4;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.67rem;
}

.s07-issue-popup-card__meta strong {
    color: #f2f6ff;
    font-size: 1.1rem;
    font-weight: 700;
}

.s07-issue-popup-card__close {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 11px;
    border: 1px solid #46516b;
    background: #222c3f;
    color: #d5def2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s07-issue-popup-card__close:hover {
    border-color: #5d6f93;
    color: #f2f6ff;
}

.s07-issue-popup-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
    gap: 1rem;
    padding: 1rem;
}

.s07-document-popup-grid {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 360px);
}

.s07-issue-popup-main,
.s07-issue-popup-summary {
    display: grid;
    gap: 0.92rem;
    align-content: start;
}

.s07-issue-popup-resume-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.s07-issue-info-card {
    border: 1px solid #31405a;
    border-radius: 10px;
    background: #1b2435;
    padding: 0.8rem;
    display: grid;
    gap: 0.22rem;
}

.s07-issue-info-card small {
    color: #a0acc3;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.68rem;
    font-weight: 700;
}

.s07-issue-info-card strong {
    color: #ecf2ff;
    font-size: 1.04rem;
}

.s07-issue-info-card p {
    margin: 0;
    color: #aebad1;
    font-size: 0.87rem;
}

.s07-issue-receptor-card {
    position: relative;
    gap: 0.5rem;
}

.s07-issue-receptor-card.is-incomplete {
    border-color: rgba(239, 68, 68, 0.55);
    box-shadow: inset 0 0 0 1px rgba(127, 29, 29, 0.28);
}

.s07-issue-receptor-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
}

.s07-issue-profile-toggle {
    border: 1px solid rgba(109, 87, 255, 0.35);
    border-radius: 9px;
    background: rgba(64, 47, 153, 0.24);
    color: #816efb;
    min-height: 2rem;
    padding: 0.28rem 0.66rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
}

.s07-issue-profile-toggle:disabled {
    opacity: 0.62;
    cursor: not-allowed;
}

.s07-issue-receptor-card__identity {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.s07-issue-receptor-status {
    border-radius: 8px;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.16rem 0.52rem;
    border: 1px solid transparent;
}

.s07-issue-receptor-status.is-complete {
    border-color: rgba(74, 222, 128, 0.5);
    background: rgba(22, 101, 52, 0.24);
    color: #86efac;
}

.s07-issue-receptor-status.is-incomplete {
    border-color: rgba(248, 113, 113, 0.55);
    background: rgba(127, 29, 29, 0.25);
    color: #fca5a5;
}

.s07-issue-receptor-alias {
    border: 1px solid rgba(133, 117, 255, 0.55);
    border-radius: 8px;
    background: rgba(63, 52, 128, 0.35);
    color: #b9c2ff;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.2rem 0.5rem;
    white-space: nowrap;
}

.s07-issue-receptor-help {
    margin: 0;
    color: #9db0cf;
    font-size: 0.76rem;
}

.s07-issue-receptor-warning {
    border: 1px solid rgba(248, 113, 113, 0.5);
    border-radius: 10px;
    background: rgba(127, 29, 29, 0.24);
    color: #fecaca;
    padding: 0.62rem 0.68rem;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.72rem;
}

.s07-issue-receptor-warning__main {
    display: grid;
    gap: 0.18rem;
}

.s07-issue-receptor-warning__main strong {
    margin: 0;
    color: #fca5a5;
    font-size: 0.9rem;
}

.s07-issue-receptor-warning__main p {
    margin: 0;
    color: #fdd3d3;
    font-size: 0.82rem;
    line-height: 1.35;
}

.s07-issue-receptor-warning__edit {
    color: #fca5a5;
    font-weight: 700;
    text-decoration: underline;
    white-space: nowrap;
}

.s07-issue-receptor-warning__edit:hover {
    color: #fecaca;
}

.s07-issue-profile-menu {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 0.45rem);
    z-index: 5;
    border: 1px solid #354865;
    border-radius: 12px;
    background: #161f2f;
    box-shadow: 0 24px 48px rgba(5, 10, 20, 0.58);
    overflow: hidden;
    padding: 0.68rem 0.68rem 0.56rem;
    display: grid;
    gap: 0.55rem;
}

.s07-issue-profile-menu__search {
    position: relative;
}

.s07-issue-profile-menu__search > i {
    position: absolute;
    left: 0.62rem;
    top: 50%;
    transform: translateY(-50%);
    color: #8799bb;
    font-size: 0.88rem;
    pointer-events: none;
}

.s07-issue-profile-menu__search input {
    width: 100%;
    border: 1px solid #344661;
    border-radius: 9px;
    background: #0f1726;
    color: #e5edff;
    min-height: 2.32rem;
    padding: 0.5rem 0.62rem 0.5rem 2rem;
}

.s07-issue-profile-menu__label {
    margin: 0;
    color: #9fb0ce;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.68rem;
    font-weight: 700;
}

.s07-issue-profile-menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
    max-height: 260px;
    overflow-y: auto;
    border: 1px solid #2d3b53;
    border-radius: 10px;
    background: #131b2a;
}

.s07-issue-profile-option {
    width: 100%;
    border: 0;
    border-bottom: 1px solid #2d3b53;
    background: #131b2a;
    color: #dfe8fb;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.55rem;
    padding: 0.72rem 0.74rem;
    text-align: left;
}

.s07-issue-profile-menu li:last-child .s07-issue-profile-option {
    border-bottom: 0;
}

.s07-issue-profile-option:hover {
    background: #1d2740;
}

.s07-issue-profile-option.is-selected {
    background: #2a2255;
}

.s07-issue-profile-option__main {
    min-width: 0;
    display: grid;
    gap: 0.18rem;
}

.s07-issue-profile-option__main strong {
    margin: 0;
    font-size: 0.95rem;
    color: #eef3ff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-profile-option__main small {
    color: #9aaccc;
    font-size: 0.78rem;
}

.s07-issue-profile-option__status {
    color: transparent;
    font-size: 1rem;
}

.s07-issue-profile-option.is-selected .s07-issue-profile-option__status {
    color: #6d57ff;
}

.s07-issue-profile-menu__empty {
    margin: 0;
    color: #9eb1d0;
    font-size: 0.76rem;
}

.s07-issue-emitter-card {
    position: relative;
    gap: 0.5rem;
}

.s07-issue-emitter-trigger {
    width: 100%;
    border: 1px solid #34445f;
    border-radius: 10px;
    background: #1b2435;
    color: #e9efff;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.55rem;
    padding: 0.65rem 0.68rem;
    text-align: left;
}

.s07-issue-emitter-trigger:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

.s07-issue-emitter-trigger__text {
    min-width: 0;
    display: grid;
    gap: 0.16rem;
}

.s07-issue-emitter-trigger__text strong {
    margin: 0;
    color: #edf2ff;
    font-size: 0.98rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-emitter-trigger__text p {
    margin: 0;
    color: #9fb0ce;
    font-size: 0.78rem;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-emitter-trigger__badge {
    border: 1px solid rgba(109, 87, 255, 0.45);
    border-radius: 8px;
    background: rgba(64, 47, 153, 0.25);
    color: #a294ff;
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    padding: 0.22rem 0.52rem;
    max-width: 150px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-emitter-trigger > i {
    color: #9aaad0;
    font-size: 1rem;
    transition: transform 0.2s ease;
}

.s07-issue-emitter-card.is-open .s07-issue-emitter-trigger > i {
    transform: rotate(180deg);
}

.s07-issue-emitter-menu {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 0.45rem);
    z-index: 4;
    border: 1px solid #354865;
    border-radius: 12px;
    background: #161f2f;
    box-shadow: 0 24px 48px rgba(5, 10, 20, 0.58);
    overflow: hidden;
}

.s07-issue-emitter-menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
    max-height: 280px;
    overflow-y: auto;
}

.s07-issue-emitter-option {
    width: 100%;
    border: 0;
    border-bottom: 1px solid #2d3b53;
    background: #161f2f;
    color: #dfe8fb;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.55rem;
    padding: 0.7rem 0.78rem;
    text-align: left;
}

.s07-issue-emitter-menu li:last-child .s07-issue-emitter-option {
    border-bottom: 0;
}

.s07-issue-emitter-option:hover {
    background: #1d2740;
}

.s07-issue-emitter-option.is-selected {
    background: #2a2255;
}

.s07-issue-emitter-option.is-incompatible {
    background: rgba(89, 29, 29, 0.25);
}

.s07-issue-emitter-option__identity {
    min-width: 0;
    display: grid;
    gap: 0.16rem;
}

.s07-issue-emitter-option__identity strong {
    margin: 0;
    font-size: 0.98rem;
    color: #eef3ff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-emitter-option__identity small {
    color: #9aaccc;
    font-size: 0.76rem;
}

.s07-issue-emitter-option__branch {
    color: #b8c5df;
    font-size: 0.8rem;
    max-width: 170px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-issue-emitter-option__status {
    color: #6d57ff;
    font-size: 1rem;
}

.s07-issue-emitter-option.is-incompatible .s07-issue-emitter-option__status {
    color: #fca5a5;
}

.s07-issue-emitter-help {
    margin: 0;
    font-size: 0.76rem;
    line-height: 1.3;
}

.s07-issue-emitter-help.is-compatible {
    color: #93c5fd;
}

.s07-issue-emitter-help.is-incompatible {
    color: #fca5a5;
}

.s07-document-banner {
    border: 1px solid #344562;
    border-radius: 11px;
    background: linear-gradient(135deg, #1f2a40 0%, #1b2a49 100%);
    padding: 0.85rem 0.95rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 1fr);
    gap: 0.9rem;
}

.s07-document-banner__eyebrow {
    margin: 0;
    color: #9eb0d1;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.68rem;
    font-weight: 700;
}

.s07-document-banner h4 {
    margin: 0.14rem 0 0;
    color: #f2f7ff;
    font-size: 1.06rem;
    font-weight: 800;
}

.s07-document-banner dl {
    margin: 0;
    display: grid;
    gap: 0.25rem;
}

.s07-document-banner dl > div {
    display: grid;
    grid-template-columns: minmax(120px, 0.6fr) minmax(0, 1fr);
    gap: 0.5rem;
    align-items: baseline;
}

.s07-document-banner dt {
    margin: 0;
    color: #95a5c1;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.s07-document-banner dd {
    margin: 0;
    color: #e6eefb;
    font-size: 0.83rem;
    word-break: break-word;
}

.s07-document-meta-cards .s07-issue-info-card {
    background: #1a2437;
}

.s07-issue-detail-table {
    border: 1px solid #2e3a53;
    border-radius: 11px;
    background: #161f2f;
    overflow: hidden;
}

.s07-issue-detail-table > header {
    padding: 0.72rem 0.85rem;
    border-bottom: 1px solid #2e3a53;
    background: #232c3d;
}

.s07-issue-detail-table > header h4 {
    margin: 0;
    color: #dbe4f8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.86rem;
}

.s07-issue-detail-table .s07-table th,
.s07-issue-detail-table .s07-table td {
    border-bottom-color: #2e3a53;
}

.s07-issue-detail-table .s07-table tbody tr:last-child td {
    border-bottom: 0;
}

.s07-issue-line-list {
    display: grid;
    gap: 0;
}

.s07-issue-line-list__empty {
    margin: 0;
    padding: 0.9rem;
    color: #aab6cd;
}

.s07-group-desglose-list {
    display: grid;
    gap: 0;
}

.s07-issue-line-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 0.44fr);
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid #2e3a53;
}

.s07-issue-line-card:last-child {
    border-bottom: 0;
}

.s07-issue-line-card__left {
    display: grid;
    gap: 0.7rem;
}

.s07-issue-line-card__identity {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: 0.62rem;
}

.s07-issue-line-card__qty {
    min-width: 2.1rem;
    height: 2.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #33405d;
    border-radius: 0.52rem;
    background: #2a344a;
    color: #d7e2f8;
    font-size: 1rem;
    font-weight: 700;
}

.s07-issue-line-card__title-wrap {
    min-width: 0;
}

.s07-issue-line-card__title-wrap h5 {
    margin: 0;
    color: #f1f5fe;
    font-size: 1.02rem;
    line-height: 1.25;
}

.s07-issue-line-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
    margin-top: 0.38rem;
}

.s07-issue-line-card__meta-badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.55rem;
    padding: 0.26rem 0.62rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: 0.01em;
    white-space: nowrap;
    box-shadow: none;
}

.s07-issue-line-card__meta-badge--payment {
    border-color: #facc15;
    background: #facc15;
    color: #111827;
}

.s07-issue-line-card__meta-badge--treatment {
    border-color: #22d3ee;
    background: #22d3ee;
    color: #082f49;
}

.s07-group-modal__summary-piece {
    display: block;
    margin-top: 0.16rem;
    color: #8fb8ff;
    font-size: 0.76rem;
    font-weight: 700;
}

.s07-issue-line-card__context {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    border: 1px solid #2d3a56;
    border-radius: 0.65rem;
    background: #151d2b;
    padding: 0.7rem 0.8rem;
}

.s07-issue-line-card__context > div {
    display: grid;
    gap: 0.14rem;
}

.s07-issue-line-card__context > div > span {
    color: #8fa0bf;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    font-size: 0.78rem;
    font-weight: 700;
}

.s07-issue-line-card__context > div > strong {
    color: #ecf3ff;
    font-size: 1.02rem;
}

.s07-issue-line-card__context > div > strong.is-paid {
    color: #48c78e;
}

.s07-issue-line-card__right {
    display: grid;
    align-content: space-between;
    gap: 0.75rem;
    border-left: 1px solid #2e3a53;
    padding-left: 0.9rem;
}

.s07-issue-line-card__right dl {
    margin: 0;
    display: grid;
    gap: 0.32rem;
}

.s07-issue-line-card__right dl > div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem;
}

.s07-issue-line-card__right dt {
    margin: 0;
    color: #9aabc8;
    font-size: 0.93rem;
}

.s07-issue-line-card__right dd {
    margin: 0;
    color: #ecf3ff;
    font-size: 0.93rem;
    font-weight: 700;
}

.s07-issue-line-card__line-total {
    display: grid;
    justify-items: end;
    gap: 0.15rem;
}

.s07-issue-line-card__line-total > span {
    color: #95a4c0;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 0.8rem;
    font-weight: 700;
}

.s07-issue-line-card__line-total > strong {
    color: #f6fbff;
    font-size: 1.85rem;
    line-height: 1;
}

.s07-issue-note-card {
    border: 1px solid rgba(59, 130, 246, 0.4);
    border-radius: 10px;
    background: rgba(30, 64, 175, 0.16);
    color: #cde1ff;
    padding: 0.8rem 0.88rem;
}

.s07-issue-note-card h5 {
    margin: 0 0 0.3rem;
    color: #7ab7ff;
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    font-size: 0.86rem;
}

.s07-issue-note-card p {
    margin: 0;
    color: #cde1ff;
    line-height: 1.35;
}

.s07-issue-summary-card {
    border: 1px solid #2f3a54;
    border-radius: 11px;
    background: #1a2334;
    padding: 0.9rem;
    display: grid;
    gap: 0.72rem;
}

.s07-issue-summary-card h4 {
    margin: 0;
    color: #e5ecfb;
    font-size: 0.92rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.s07-issue-summary-card dl {
    margin: 0;
    display: grid;
    gap: 0.4rem;
}

.s07-issue-summary-card dl > div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem;
    font-size: 0.84rem;
    color: #9eaac2;
}

.s07-issue-summary-card dl > div dd {
    text-align: right;
    word-break: break-word;
    max-width: 68%;
}

.s07-issue-summary-card dt,
.s07-issue-summary-card dd {
    margin: 0;
}

.s07-issue-summary-total {
    border-top: 1px solid #2f3a54;
    padding-top: 0.62rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.s07-issue-summary-total span {
    color: #dce6f8;
    font-weight: 700;
}

.s07-issue-summary-total strong {
    color: #f6f9ff;
    font-size: 1.7rem;
    font-weight: 800;
    font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.s07-issue-emit-form {
    display: grid;
    gap: 0.54rem;
}

.s07-issue-emit-form label {
    margin: 0.2rem 0 0;
    color: #b9c6de;
    font-size: 0.76rem;
    font-weight: 600;
}

.s07-issue-emit-form select {
    border: 1px solid #34435d;
    background: #1a2334;
    color: #e6edfc;
    min-height: 2.44rem;
    border-radius: 10px;
    padding: 0.52rem 0.72rem;
}

.s07-issue-readonly-field {
    margin: 0;
    border: 1px solid #34435d;
    border-radius: 10px;
    background: #1a2334;
    color: #e6edfc;
    min-height: 2.44rem;
    display: flex;
    align-items: center;
    padding: 0.52rem 0.72rem;
    font-size: 0.83rem;
}

.s07-issue-payment-badge {
    width: fit-content;
    padding: 0.2rem 0.62rem;
    font-size: 0.76rem;
}

.s07-issue-emit-form textarea {
    border: 1px solid #34435d;
    background: #1a2334;
    color: #e6edfc;
    border-radius: 10px;
    padding: 0.52rem 0.72rem;
    resize: vertical;
    min-height: 4.2rem;
    line-height: 1.4;
}

.s07-issue-link-alias {
    margin-top: 0.1rem;
    justify-content: center;
}

.s07-issue-emit-primary,
.s07-issue-emit-secondary {
    min-height: 2.65rem;
    justify-content: center;
    font-weight: 700;
}

.s07-issue-signature-card {
    border: 1px solid #2f3a54;
    border-radius: 11px;
    background: #1a2334;
    padding: 0.72rem 0.8rem;
    display: inline-flex;
    align-items: center;
    gap: 0.58rem;
}

.s07-issue-signature-card > i {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.18);
    color: #4ade80;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s07-issue-signature-card strong {
    display: block;
    color: #e7eefc;
    font-size: 0.86rem;
}

.s07-issue-signature-card p {
    margin: 0.14rem 0 0;
    color: #a4b2cb;
    font-size: 0.76rem;
}

.s07-issue-confirm {
    position: fixed;
    inset: 0;
    z-index: 1240;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.s07-issue-confirm[hidden] {
    display: none !important;
}

.s07-issue-confirm__backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(7, 10, 17, 0.72);
    backdrop-filter: blur(2px);
}

.s07-issue-confirm__dialog {
    position: relative;
    width: min(860px, 95vw);
    border-radius: 18px;
    border: 1px solid #36415a;
    background: #1b2232;
    box-shadow: 0 24px 52px rgba(2, 6, 23, 0.58);
    padding: 1.28rem 1.35rem 1rem;
    text-align: center;
    color: #e6edf8;
    display: grid;
    gap: 0.86rem;
}

.s07-issue-confirm__icon {
    width: 5rem;
    height: 5rem;
    border-radius: 999px;
    border: 1px solid rgba(251, 191, 36, 0.35);
    background: rgba(180, 83, 9, 0.15);
    color: #fbbf24;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.1rem;
    margin: 0 auto;
}

.s07-issue-confirm__dialog h5 {
    margin: 0;
    color: #f8fafc;
    font-size: 2.25rem;
    line-height: 1.2;
}

.s07-issue-confirm__dialog p {
    margin: 0 auto;
    color: #c5d0e6;
    font-size: 0.95rem;
    line-height: 1.5;
    max-width: 620px;
}

.s07-issue-confirm.is-pending .s07-issue-confirm__dialog {
    border-color: rgba(96, 165, 250, 0.48);
    box-shadow: 0 24px 52px rgba(2, 6, 23, 0.62), 0 0 0 1px rgba(96, 165, 250, 0.12);
}

.s07-issue-confirm.is-pending .s07-issue-confirm__icon {
    border-color: rgba(96, 165, 250, 0.42);
    background: rgba(30, 64, 175, 0.18);
    color: #7dd3fc;
}

.s07-issue-confirm__pending {
    display: grid;
    gap: 0.72rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(96, 165, 250, 0.28);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(18, 30, 50, 0.94), rgba(13, 23, 39, 0.92));
    text-align: left;
}

.s07-issue-confirm__pending-head {
    display: flex;
    align-items: flex-start;
    gap: 0.72rem;
}

.s07-issue-confirm__pending-spinner {
    width: 2.65rem;
    height: 2.65rem;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid rgba(125, 211, 252, 0.3);
    background: rgba(24, 46, 78, 0.9);
    color: #7dd3fc;
    font-size: 1.1rem;
}

.s07-issue-confirm__pending-copy {
    display: grid;
    gap: 0.22rem;
    min-width: 0;
}

.s07-issue-confirm__pending-copy strong {
    color: #f6f9ff;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.25;
}

.s07-issue-confirm__pending-copy p {
    margin: 0;
    max-width: none;
    color: #b8c8e2;
    font-size: 0.88rem;
    line-height: 1.45;
}

.s07-issue-confirm__pending-progress {
    position: relative;
    overflow: hidden;
    height: 0.5rem;
    border-radius: 999px;
    background: rgba(110, 127, 162, 0.22);
}

.s07-issue-confirm__pending-progress::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 -38%;
    width: 38%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(125, 211, 252, 0.18), rgba(125, 211, 252, 0.96), rgba(125, 211, 252, 0.18));
    animation: s07-issue-confirm-progress 1.05s ease-in-out infinite;
}

.s07-issue-confirm__pending-meta {
    color: #d9e5fb;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.s07-issue-confirm__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.82rem;
    margin-top: 0.15rem;
}

.s07-issue-confirm__actions .btn {
    min-height: 3.25rem;
    justify-content: center;
    font-weight: 700;
    border-radius: 13px;
    font-size: 1.05rem;
}

.s07-issue-confirm__actions .btn:disabled {
    cursor: progress;
    opacity: 0.74;
}

.s07-issue-confirm__btn-spinner {
    margin-right: 0.42rem;
}

.s07-issue-confirm__meta {
    margin-top: 0.1rem;
    border-top: 1px solid #303a53;
    padding-top: 0.7rem;
    display: flex;
    justify-content: space-between;
    gap: 0.6rem;
    color: #8f9ab2;
    font-size: 0.9rem;
}

.s07-issue-confirm__meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

@keyframes s07-issue-confirm-progress {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(365%);
    }
}

@media (prefers-reduced-motion: reduce) {
    html:focus-within {
        scroll-behavior: auto;
    }

    body.admin-shell *,
    body.admin-shell *::before,
    body.admin-shell *::after,
    body.admin-auth-body *,
    body.admin-auth-body *::before,
    body.admin-auth-body *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }

    .auth-inline-spinner {
        animation: none !important;
        border-top-color: rgba(255, 255, 255, 0.78);
    }

    .s07-issue-confirm__pending-progress::before {
        inset: 0 auto 0 0;
        width: 58%;
        transform: none !important;
        animation: none !important;
    }
}

.s07-fiscal-offcanvas {
    position: fixed;
    inset: 0;
    z-index: 1220;
    pointer-events: none;
}

body.s07-fiscal-panel-open {
    overflow: hidden;
}

.s07-fiscal-offcanvas__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(4, 9, 20, 0.7);
    backdrop-filter: blur(2px);
    opacity: 0;
    transition: opacity 0.22s ease;
}

.s07-fiscal-offcanvas__panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(560px, 96vw);
    border-left: 1px solid #2e3a50;
    background: linear-gradient(160deg, #161d2a 0%, #131a28 100%);
    box-shadow: -24px 0 48px rgba(2, 7, 18, 0.52);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.24s ease;
}

.s07-fiscal-offcanvas.is-open {
    pointer-events: auto;
}

.s07-fiscal-offcanvas.is-open .s07-fiscal-offcanvas__backdrop {
    opacity: 1;
}

.s07-fiscal-offcanvas.is-open .s07-fiscal-offcanvas__panel {
    transform: translateX(0);
}

.s07-fiscal-offcanvas__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 1rem 1rem 0.85rem;
    border-bottom: 1px solid #2b3548;
}

.s07-fiscal-offcanvas__header h2 {
    margin: 0;
    color: #f0f4ff;
    font-size: 1.22rem;
    letter-spacing: -0.01em;
}

.s07-fiscal-offcanvas__header p {
    margin: 0.28rem 0 0;
    color: #9aa9c5;
    font-size: 0.83rem;
}

.s07-fiscal-offcanvas__close {
    width: 1.9rem;
    height: 1.9rem;
    border-radius: 8px;
    border: 1px solid #36435b;
    background: #1b2435;
    color: #c3d0e8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.s07-fiscal-offcanvas__close:hover {
    border-color: #506389;
    color: #ebf2ff;
}

.s07-fiscal-offcanvas__body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0.95rem 1rem 1rem;
    display: grid;
    gap: 0.9rem;
}

.s07-fiscal-loading {
    border: 1px dashed #3c4d6a;
    border-radius: 10px;
    padding: 0.85rem;
    color: #9eacc8;
    font-size: 0.84rem;
}

.s07-fiscal-alert {
    border-radius: 10px;
    border: 1px solid transparent;
    padding: 0.62rem 0.74rem;
    font-size: 0.82rem;
}

.s07-fiscal-alert ul {
    margin: 0.28rem 0 0 1rem;
    padding: 0;
}

.s07-fiscal-alert--success {
    border-color: rgba(74, 222, 128, 0.4);
    background: rgba(22, 101, 52, 0.32);
    color: #bbf7d0;
}

.s07-fiscal-alert--danger {
    border-color: rgba(248, 113, 113, 0.44);
    background: rgba(127, 29, 29, 0.33);
    color: #fee2e2;
}

.s07-fiscal-alert--warning {
    border-color: rgba(250, 204, 21, 0.34);
    background: rgba(120, 53, 15, 0.26);
    color: #fde68a;
}

.s07-fiscal-section {
    border-radius: 12px;
    border: 1px solid #2f3a50;
    background: #192234;
    padding: 0.8rem 0.85rem;
}

.s07-fiscal-section--accordion {
    padding: 0.32rem 0.55rem;
}

.s07-fiscal-section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    margin-bottom: 0.62rem;
}

.s07-fiscal-section__header h4 {
    margin: 0;
    color: #eef3ff;
    font-size: 0.92rem;
}

.s07-fiscal-accordion {
    display: block;
    margin: 0;
}

.s07-fiscal-accordion[open] {
    padding-bottom: 0.18rem;
}

.s07-fiscal-accordion:not([open]) .s07-fiscal-accordion__body {
    display: none;
}

.s07-fiscal-accordion__summary {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    padding: 0.12rem 0.18rem 0.14rem;
    cursor: pointer;
    color: #eef3ff;
    margin: 0;
}

.s07-fiscal-accordion__summary::-webkit-details-marker {
    display: none;
}

.s07-fiscal-accordion__title {
    font-size: 0.9rem;
    font-weight: 700;
    color: #eef3ff;
}

.s07-fiscal-accordion__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    color: #8ea0c2;
    flex-shrink: 0;
}

.s07-fiscal-accordion__meta .las {
    font-size: 0.98rem;
    transition: transform 0.18s ease;
}

.s07-fiscal-accordion[open] .s07-fiscal-accordion__meta .las {
    transform: rotate(180deg);
}

.s07-fiscal-accordion__body {
    padding-top: 0.45rem;
    border-top: 1px solid rgba(56, 70, 95, 0.72);
    margin-top: 0.18rem;
}

.s07-fiscal-empty {
    border: 1px dashed #3a4963;
    border-radius: 10px;
    padding: 0.72rem;
    color: #9cacca;
    font-size: 0.82rem;
}

.s07-fiscal-alias-list {
    display: grid;
    gap: 0.55rem;
}

.s07-fiscal-alias-item {
    border: 1px solid #33425c;
    border-radius: 10px;
    background: #1d2739;
    padding: 0.62rem 0.68rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.55rem;
    align-items: center;
}

.s07-fiscal-alias-item.is-inactive {
    opacity: 0.72;
    border-color: #4f3e53;
}

.s07-fiscal-alias-item--exception {
    background: #1a2435;
}

.s07-fiscal-alias-item__main {
    min-width: 0;
}

.s07-fiscal-alias-item__main strong {
    display: block;
    color: #eef3ff;
    font-size: 0.88rem;
}

.s07-fiscal-alias-item__main small {
    display: block;
    color: #9eacc7;
    font-size: 0.76rem;
    margin-top: 0.14rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-fiscal-alias-item__badges {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    margin-top: 0.24rem;
}

.s07-fiscal-alias-item__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.s07-fiscal-alias-item__actions form {
    margin: 0;
}

.s07-profile-form--offcanvas {
    gap: 0.68rem;
}

.s07-profile-form--offcanvas .field {
    gap: 0.3rem;
}

.s07-id-type-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2391a2c6' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-position: right 0.72rem center;
    background-size: 0.9rem 0.9rem;
    background-repeat: no-repeat;
    padding-right: 2.3rem !important;
    height: 2.44rem;
    line-height: 1.15;
}

.s07-id-type-select::-ms-expand {
    display: none;
}

.s07-field-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.s07-profile-form--offcanvas label {
    font-size: 0.8rem;
    color: #becbe2;
    font-weight: 600;
}

.s07-field-state {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: #8a98b6;
}

.s07-field-state.is-valid {
    color: #5ce8a6;
}

.s07-field-state--spacer {
    visibility: hidden;
}

.s07-field-feedback {
    display: block;
    min-height: 1rem;
    margin-top: 0.05rem;
    font-size: 0.74rem;
    color: #8d9bb7;
}

.s07-field-feedback.is-error {
    color: #ff7f7f;
}

.s07-fiscal-exception-callout {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.2rem;
}

.s07-fiscal-exception-callout p {
    margin: 0;
    color: inherit;
    font-size: 0.78rem;
    line-height: 1.45;
}

.s07-fiscal-exception-callout__action {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.s07-profile-form--offcanvas input,
.s07-profile-form--offcanvas select,
.s07-profile-form--offcanvas textarea {
    border: 1px solid #36455e;
    background: #1a2335;
    color: #e7eeff;
    border-radius: 9px;
    min-height: 2.44rem;
    padding: 0.52rem 0.74rem;
    font-size: 0.84rem;
}

.s07-profile-form--offcanvas .s07-form-grid {
    align-items: start;
}

.s07-profile-form--offcanvas input::placeholder,
.s07-profile-form--offcanvas textarea::placeholder {
    color: #8595b3;
}

.s07-profile-form--offcanvas .s07-input-valid {
    border-color: rgba(76, 214, 152, 0.85);
    box-shadow: 0 0 0 1px rgba(42, 161, 112, 0.3);
}

.s07-profile-form--offcanvas .s07-input-invalid {
    border-color: rgba(248, 113, 113, 0.9);
    box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.28);
}

.s07-profile-form--offcanvas .s07-id-type-select:focus {
    outline: none;
    border-color: #4e6da1;
    box-shadow: 0 0 0 1px rgba(78, 109, 161, 0.35);
}

.s07-profile-form--offcanvas textarea {
    min-height: 74px;
}

.s07-profile-form--offcanvas .checkbox {
    color: #c6d2ea;
    font-size: 0.8rem;
}

.s07-fiscal-form-actions {
    justify-content: flex-end;
    margin-top: 0.1rem;
}

@media (max-width: 760px) {
    .s07-fiscal-offcanvas__panel {
        width: 100vw;
        border-radius: 0;
    }

    .s07-fiscal-offcanvas__body {
        padding: 0.82rem;
    }

    .s07-fiscal-alias-item {
        grid-template-columns: 1fr;
    }

    .s07-fiscal-alias-item__actions {
        justify-content: flex-end;
    }

    .s07-profile-form--offcanvas .s07-form-grid {
        grid-template-columns: 1fr;
    }
}

.s12-screen.shell {
    width: min(1320px, 96vw);
}

body.admin-shell .s12-screen.shell.card,
body.admin-shell .s12-form-screen.shell.card {
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.admin-shell .s12-screen.panel,
body.admin-shell .s12-form-screen.panel {
    padding: 0;
}

.s12-form-screen.shell {
    width: min(980px, 95vw);
}

.s12-screen__header,
.s12-form-screen__header {
    align-items: flex-start;
    margin-bottom: 1rem;
}

.s12-screen__eyebrow {
    margin: 0 0 0.15rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 700;
    color: #8f96a8;
}

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

.s12-kpi-card h2 {
    margin: 0.35rem 0 0.6rem;
    font-size: clamp(1.4rem, 2.2vw, 2rem);
    color: #f1f5ff;
}

.s12-filters-card,
.s12-table-card,
.s12-form-card,
.s12-modal-card,
.s12-dentalink-credential-card {
    border-radius: 12px;
}

.s12-dentalink-credential-card {
    display: grid;
    gap: 1rem;
    border-color: rgba(96, 165, 250, 0.28);
    background:
        linear-gradient(135deg, rgba(37, 99, 235, 0.13), rgba(15, 23, 42, 0.72) 42%),
        #151d2c;
}

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

.s12-dentalink-credential-card__header h2 {
    margin: 0;
    color: #f1f5ff;
    font-size: 1.08rem;
}

.s12-dentalink-credential-grid {
    display: grid;
    grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.4fr);
    gap: 1rem;
    align-items: start;
}

.s12-dentalink-credential-status {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.8rem;
    align-items: start;
    padding: 0.9rem;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 10px;
    background: rgba(15, 23, 42, 0.44);
}

.s12-dentalink-credential-status strong,
.s12-dentalink-credential-status small {
    display: block;
}

.s12-dentalink-credential-status strong {
    color: #eef2ff;
}

.s12-dentalink-credential-status small {
    margin-top: 0.25rem;
    color: #94a3b8;
}

.s12-dentalink-credential-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.s12-dentalink-credential-toggle,
.s12-dentalink-credential-actions {
    grid-column: 1 / -1;
}

.s12-dentalink-credential-actions {
    justify-content: flex-end;
}

.s12-filters-form {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(180px, 0.5fr) minmax(180px, 0.5fr) auto;
    gap: 0.85rem;
    align-items: end;
}

.s12-filters-actions {
    justify-content: flex-end;
}

.s12-table-card {
    padding: 0;
    overflow: hidden;
}

.s12-table-card__header,
.s12-table-card__footer {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.s12-table-card__header {
    border-bottom: 1px solid #2f394d;
}

.s12-table-card__footer {
    border-top: 1px solid #2f394d;
}

.s12-table-card__header h2 {
    margin: 0;
    font-size: 1.06rem;
}

.s12-table-wrap {
    overflow-x: auto;
}

.s12-table {
    width: 100%;
    border-collapse: collapse;
}

.s12-table th,
.s12-table td {
    padding: 0.8rem 0.85rem;
    border-bottom: 1px solid #2f394d;
    vertical-align: top;
    text-align: left;
    font-size: 0.86rem;
}

.s12-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #b4bfd5;
    background: #1b2230;
}

.s12-table tbody tr:hover td {
    background: #1d2535;
}

.s12-table td strong {
    display: block;
    color: #eef2fb;
    font-size: 0.88rem;
}

.s12-table td small {
    display: block;
    margin-top: 0.12rem;
    color: #8f9bb1;
    font-size: 0.74rem;
}

.s12-table .is-right {
    text-align: right;
}

.s12-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.12rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.s12-pill--admin {
    border-color: rgba(147, 197, 253, 0.5);
    color: #bfdbfe;
    background: rgba(30, 64, 175, 0.3);
}

.s12-pill--operator {
    border-color: rgba(196, 181, 253, 0.52);
    color: #ddd6fe;
    background: rgba(76, 29, 149, 0.32);
}

.s12-pill--active {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s12-pill--inactive {
    border-color: rgba(148, 163, 184, 0.42);
    color: #cbd5e1;
    background: rgba(30, 41, 59, 0.45);
}

.s12-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.3rem;
    flex-wrap: wrap;
}

.s12-action-btn {
    width: 2.35rem;
    height: 2.35rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s12-action-btn i {
    font-size: 1rem;
    line-height: 1;
}

.s12-screen .btn-xs {
    padding: 0.38rem 0.62rem;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: 8px;
}

.s12-screen .btn.is-disabled {
    opacity: 0.58;
    cursor: not-allowed;
}

.s12-actions .is-danger {
    border-color: rgba(248, 113, 113, 0.4);
    color: #fecaca;
}

.s12-actions .is-success {
    border-color: rgba(74, 222, 128, 0.4);
    color: #86efac;
}

.s12-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.s12-state-card {
    min-height: 120px;
}

.s12-empty-state {
    min-height: 220px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1.5rem 1.2rem;
}

.s12-empty-state h2,
.s12-empty-state h3 {
    margin: 0.4rem 0 0.2rem;
    color: #edf2fc;
}

.s12-empty-state--table {
    min-height: 180px;
}

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

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

.s12-form-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
    margin-top: 0.2rem;
}

.s12-checkbox {
    margin-top: 1.8rem;
}

.s12-edit-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding-bottom: 0.25rem;
    border-bottom: 1px solid #2f394d;
}

.s12-edit-meta h2 {
    margin: 0;
    font-size: 1.12rem;
}

.s12-edit-footer {
    border-top: 1px solid #2f394d;
    padding-top: 0.75rem;
}

.s12-modal-card__header h2 {
    margin: 0;
    font-size: 1.12rem;
}

.s12-modal-form {
    display: grid;
    gap: 0.8rem;
}

.s12-modal-actions {
    justify-content: flex-end;
    margin-top: 0.4rem;
}

.s12-btn-danger {
    border-color: rgba(248, 113, 113, 0.4);
    background: rgba(127, 29, 29, 0.18);
    color: #fecaca;
}

.s12-btn-danger:hover {
    border-color: rgba(248, 113, 113, 0.6);
    background: rgba(127, 29, 29, 0.32);
    color: #fee2e2;
}

.s08-screen.shell {
    width: min(1320px, 96vw);
}

body.admin-shell .s08-screen.shell.card {
    background: #1f2025;
    border: 1px solid #363841;
}

.s08-screen__header {
    margin-bottom: 0.45rem;
}

.s08-screen__actions {
    justify-content: flex-end;
}

.s08-refresh-btn {
    gap: 0.42rem;
}

.s08-refresh-btn .spinner-border {
    width: 0.82rem;
    height: 0.82rem;
    border-width: 0.14em;
}

.s08-refresh-btn.is-loading {
    pointer-events: none;
    opacity: 0.88;
}

.s08-screen__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #8f96a8;
    font-weight: 700;
}

.s08-state-card {
    min-height: 140px;
}

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

.s08-kpi-card {
    border-radius: 12px;
    min-height: 150px;
}

.s08-kpi-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.65rem;
}

.s08-kpi-card__label {
    margin: 0;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8f96a8;
    font-weight: 700;
}

.s08-kpi-card__value {
    margin: 0.6rem 0 0.45rem;
    font-size: clamp(1.3rem, 2vw, 1.95rem);
    font-weight: 800;
    color: #eef2fb;
}

.s08-alerts-card {
    border-radius: 12px;
}

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

.s08-alert-item {
    border-left: 4px solid transparent;
    border-radius: 10px;
    padding: 0.86rem 0.92rem;
    background: #22252f;
}

.s08-alert-item__title {
    margin: 0 0 0.35rem;
    font-size: 0.92rem;
    font-weight: 700;
}

.s08-alert-item--success {
    border-left-color: rgba(74, 222, 128, 0.75);
    background: rgba(22, 101, 52, 0.28);
}

.s08-alert-item--success .s08-alert-item__title {
    color: #86efac;
}

.s08-alert-item--warning {
    border-left-color: rgba(252, 211, 77, 0.75);
    background: rgba(120, 74, 13, 0.3);
}

.s08-alert-item--warning .s08-alert-item__title {
    color: #fcd34d;
}

.s08-alert-item--danger {
    border-left-color: rgba(248, 113, 113, 0.72);
    background: rgba(127, 29, 29, 0.33);
}

.s08-alert-item--danger .s08-alert-item__title {
    color: #fecaca;
}

.s08-table-card {
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}

.s08-screen .btn-xs {
    padding: 0.38rem 0.62rem;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: 8px;
    width: auto;
    height: auto;
    min-width: 0;
    min-height: 0;
}

.s08-table-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid #2f394d;
}

.s08-table-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
    border-top: 1px solid #2f394d;
}

.s08-table-card__header h2 {
    margin: 0;
    font-size: 1.06rem;
}

.s08-tabs {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.75rem 1.1rem;
    border-bottom: 1px solid #2f394d;
    overflow-x: auto;
}

.s08-tabs__item {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    border: 1px solid #3a4660;
    border-radius: 999px;
    padding: 0.32rem 0.64rem;
    color: #b4bfd5;
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.s08-tabs__item:hover {
    border-color: #6f84aa;
    color: #d9e4fb;
}

.s08-tabs__item.is-active {
    border-color: rgba(147, 197, 253, 0.52);
    background: rgba(30, 64, 175, 0.32);
    color: #dbeafe;
}

.s08-tabs__count {
    border-radius: 999px;
    padding: 0.05rem 0.38rem;
    background: rgba(15, 23, 42, 0.48);
    font-size: 0.7rem;
    line-height: 1.25;
}

.s08-table-wrap {
    overflow-x: auto;
}

.s08-table {
    width: 100%;
    border-collapse: collapse;
}

.s08-table th,
.s08-table td {
    padding: 0.8rem 0.85rem;
    border-bottom: 1px solid #2f394d;
    vertical-align: top;
    text-align: left;
    font-size: 0.86rem;
}

.s08-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #b4bfd5;
    background: #1b2230;
}

.s08-table tbody tr:hover td {
    background: #1d2535;
}

.s08-table .is-center {
    text-align: center;
}

.s08-table .is-right {
    text-align: right;
}

.s08-row-primary {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
}

.s08-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.s08-detail {
    max-width: 360px;
}

.s08-mono {
    font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.78rem;
}

.s08-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.12rem 0.52rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.s08-pill--success {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s08-pill--warning {
    border-color: rgba(252, 211, 77, 0.46);
    color: #fcd34d;
    background: rgba(120, 74, 13, 0.36);
}

.s08-pill--danger {
    border-color: rgba(248, 113, 113, 0.48);
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.s08-pill--info {
    border-color: rgba(96, 165, 250, 0.5);
    color: #bfdbfe;
    background: rgba(30, 64, 175, 0.3);
}

.s08-pill--neutral {
    border-color: rgba(148, 163, 184, 0.44);
    color: #cbd5e1;
    background: rgba(30, 41, 59, 0.45);
}

.s08-row-status {
    display: grid;
    align-content: start;
    gap: 0.32rem;
}

.s08-inline-progress {
    display: grid;
    gap: 0.22rem;
    min-width: 130px;
}

.s08-inline-progress__track {
    height: 0.32rem;
    margin: 0;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.2);
}

.s08-inline-progress__label {
    margin: 0;
    font-size: 0.64rem;
    letter-spacing: 0.02em;
    color: #9ba7bc;
}

.s08-action-btn {
    width: 2.2rem;
    height: 2.2rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s08-action-btn i {
    font-size: 1rem;
}

body.s08-detail-modal-open {
    overflow: hidden;
}

.s08-detail-modal {
    position: fixed;
    inset: 0;
    z-index: 1700;
    display: grid;
    place-items: center;
    padding: 1rem;
}

.s08-detail-modal[hidden] {
    display: none;
}

.s08-detail-modal__backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(15, 23, 42, 0.78);
}

.s08-detail-modal__panel {
    position: relative;
    width: min(700px, 96vw);
    max-height: 90vh;
    overflow: auto;
    border-radius: 14px;
    border: 1px solid #334155;
    background: #182132;
    box-shadow: 0 18px 48px rgba(2, 6, 23, 0.55);
}

.s08-detail-modal__header {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid #334155;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.s08-detail-modal__header h2 {
    margin: 0;
    font-size: 1.02rem;
    color: #e2e8f0;
}

.s08-detail-modal__body {
    padding: 1rem;
    display: grid;
    gap: 1rem;
}

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

.s08-detail-grid div {
    border: 1px solid #334155;
    border-radius: 10px;
    padding: 0.72rem 0.78rem;
    background: #121a29;
}

.s08-detail-grid dt {
    margin: 0 0 0.3rem;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #94a3b8;
}

.s08-detail-grid dd {
    margin: 0;
    color: #e2e8f0;
    font-size: 0.94rem;
}

.s08-detail-message {
    border: 1px solid #334155;
    border-radius: 10px;
    padding: 0.82rem 0.9rem;
    background: #121a29;
}

.s08-detail-message h3 {
    margin: 0 0 0.45rem;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #94a3b8;
}

.s08-detail-message p {
    margin: 0;
    color: #e2e8f0;
    line-height: 1.45;
}

.s08-empty-table {
    min-height: 180px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1.2rem;
}

.s08-mobile-list {
    display: none;
}

.s08-mobile-item {
    border-top: 1px solid #2f394d;
    padding: 0.95rem 1.1rem;
    display: grid;
    gap: 0.48rem;
}

.s08-mobile-item__top,
.s08-mobile-item__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.s08-mobile-item__event {
    margin: 0;
    color: #e6ebf8;
    font-weight: 600;
}

@media (max-width: 640px) {
    .s08-detail-grid {
        grid-template-columns: 1fr;
    }
}

.s13-screen.shell {
    width: min(1360px, 96vw);
}

body.admin-shell .s13-screen.shell.card {
    background: #1f2025;
    border: 1px solid #363841;
}

.s13-screen__header {
    margin-bottom: 0.45rem;
}

.s13-screen__actions {
    justify-content: flex-end;
}

.s13-screen__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #8f96a8;
    font-weight: 700;
}

.s13-state-card {
    min-height: 140px;
}

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

.s13-skeleton-item {
    min-height: 66px;
    border-radius: 10px;
    border: 1px solid #2f394d;
    background: linear-gradient(120deg, #242b38 0%, #2b3345 35%, #242b38 70%);
    background-size: 200% 100%;
    animation: s13-shimmer 1.8s linear infinite;
}

@keyframes s13-shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

.s13-filters-card {
    border-radius: 12px;
}

.s13-filters-form {
    display: grid;
    grid-template-columns: minmax(280px, 1.6fr) minmax(190px, 0.9fr) minmax(190px, 0.9fr) minmax(190px, 0.9fr) auto;
    gap: 0.82rem;
    align-items: end;
}

.s13-filters-actions {
    justify-content: flex-end;
}

.s13-summary-card {
    border-radius: 12px;
}

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

.s13-summary-item {
    border: 1px solid #2f394d;
    border-radius: 10px;
    background: #22252f;
    padding: 0.72rem 0.78rem;
    display: grid;
    gap: 0.18rem;
}

.s13-summary-item p {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #94a0b9;
    font-weight: 700;
}

.s13-summary-item strong {
    color: #f0f4fd;
    font-size: 1.34rem;
    line-height: 1;
}

.s13-summary-item strong.is-danger {
    color: #fca5a5;
}

.s13-summary-item strong.is-warning {
    color: #fcd34d;
}

.s13-summary-item strong.is-info {
    color: #93c5fd;
}

.s13-table-card {
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}

.s13-screen .btn-xs {
    padding: 0.38rem 0.62rem;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: 8px;
    width: auto;
    height: auto;
    min-width: 0;
    min-height: 0;
}

.s13-table-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid #2f394d;
}

.s13-table-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
    border-top: 1px solid #2f394d;
}

.s13-table-card__header h2 {
    margin: 0;
    font-size: 1.06rem;
}

.s13-table-wrap {
    overflow-x: auto;
}

.s13-table {
    width: 100%;
    border-collapse: collapse;
}

.s13-table th,
.s13-table td {
    padding: 0.8rem 0.85rem;
    border-bottom: 1px solid #2f394d;
    vertical-align: top;
    text-align: left;
    font-size: 0.84rem;
}

.s13-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #b4bfd5;
    background: #1b2230;
    white-space: nowrap;
}

.s13-table tbody tr:hover td {
    background: #1d2535;
}

.s13-table tbody tr.is-active td {
    background: rgba(40, 61, 98, 0.52);
}

.s13-table .is-right {
    text-align: right;
}

.s13-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.s13-detail {
    max-width: 320px;
}

.s13-mono {
    font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.76rem;
}

.s13-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.12rem 0.52rem;
    font-size: 0.69rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.s13-pill--success {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s13-pill--warning {
    border-color: rgba(252, 211, 77, 0.46);
    color: #fcd34d;
    background: rgba(120, 74, 13, 0.36);
}

.s13-pill--danger {
    border-color: rgba(248, 113, 113, 0.48);
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.s13-pill--info {
    border-color: rgba(96, 165, 250, 0.5);
    color: #bfdbfe;
    background: rgba(30, 64, 175, 0.3);
}

.s13-pill--neutral {
    border-color: rgba(148, 163, 184, 0.44);
    color: #cbd5e1;
    background: rgba(30, 41, 59, 0.45);
}

.s13-action-btn {
    width: 2.15rem;
    height: 2.15rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s13-action-btn i {
    font-size: 1rem;
}

.s13-empty-table {
    min-height: 180px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1.2rem;
}

.s13-mobile-list {
    display: none;
}

.s13-mobile-item {
    border-top: 1px solid #2f394d;
    padding: 0.95rem 1.1rem;
    display: grid;
    gap: 0.5rem;
}

.s13-mobile-item__top,
.s13-mobile-item__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.s13-mobile-item__event {
    margin: 0;
    color: #e6ebf8;
    font-weight: 600;
}

.s15-screen.shell {
    width: min(1360px, 96vw);
}

body.admin-shell .s15-screen.shell.card {
    background: #1f2025;
    border: 1px solid #363841;
}

.s15-screen__header {
    margin-bottom: 0.45rem;
}

.s15-screen__actions {
    justify-content: flex-end;
}

.s15-screen__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #8f96a8;
    font-weight: 700;
}

.s15-connection-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.24rem 0.7rem;
    font-size: 0.72rem;
    font-weight: 700;
}

.s15-connection-pill--success {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s15-connection-pill--danger {
    border-color: rgba(248, 113, 113, 0.48);
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.s15-connection-pill--neutral {
    border-color: rgba(148, 163, 184, 0.44);
    color: #cbd5e1;
    background: rgba(30, 41, 59, 0.45);
}

.s15-state-card {
    min-height: 130px;
}

.s15-config-grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    align-items: start;
}

.s15-settings-card,
.s15-preview-card,
.s15-send-test-card {
    border-radius: 12px;
}

.s15-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.s15-card-header h2 {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 1.02rem;
}

.s15-card-header small {
    color: #8f9bb1;
}

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

.s15-field-full {
    grid-column: 1 / -1;
}

.s15-settings-card .field small {
    color: #8f9bb1;
}

.s15-toggle-grid {
    display: grid;
    gap: 0.4rem;
}

.s15-security-note {
    display: flex;
    gap: 0.6rem;
    align-items: flex-start;
    border: 1px solid #3a4660;
    border-radius: 10px;
    padding: 0.68rem 0.75rem;
    background: rgba(15, 23, 42, 0.26);
    color: #cdd8f1;
}

.s15-security-note i {
    margin-top: 0.06rem;
    color: #93c5fd;
    font-size: 1.02rem;
}

.s15-security-note p {
    margin: 0;
    font-size: 0.81rem;
}

.s15-mail-preview {
    border: 1px solid #2f394d;
    border-radius: 12px;
    background: #1b2230;
    padding: 0.95rem;
    display: grid;
    gap: 0.52rem;
}

.s15-mail-preview h3 {
    margin: 0;
    font-size: 0.98rem;
}

.s15-mail-preview p {
    margin: 0;
    color: #c7d2e8;
    font-size: 0.82rem;
}

.s15-preview-attachments {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.s15-preview-attachments span {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    border: 1px solid #3a4660;
    border-radius: 999px;
    padding: 0.2rem 0.58rem;
    font-size: 0.73rem;
}

.s15-send-test-form {
    display: grid;
    gap: 0.7rem;
}

.s15-context-note {
    margin: 0;
}

.s15-use-patient-email {
    justify-content: center;
}

.s15-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.7rem;
}

.s15-summary-card {
    display: grid;
    gap: 0.2rem;
    border-radius: 12px;
}

.s15-summary-card p {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #94a0b9;
    font-weight: 700;
}

.s15-summary-card strong {
    font-size: 1.35rem;
    color: #f0f4fd;
    line-height: 1;
}

.s15-summary-card strong.is-success {
    color: #86efac;
}

.s15-summary-card strong.is-danger {
    color: #fca5a5;
}

.s15-summary-card strong.is-neutral {
    color: #cbd5e1;
    font-size: 0.94rem;
}

.s15-table-card {
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}

.s15-table-card__header,
.s15-table-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
}

.s15-table-card__header {
    border-bottom: 1px solid #2f394d;
}

.s15-table-card__footer {
    border-top: 1px solid #2f394d;
}

.s15-table-card__header h2 {
    margin: 0;
    font-size: 1.06rem;
}

.s15-table-wrap {
    overflow-x: auto;
}

.s15-table {
    width: 100%;
    border-collapse: collapse;
}

.s15-table th,
.s15-table td {
    padding: 0.8rem 0.82rem;
    border-bottom: 1px solid #2f394d;
    vertical-align: top;
    text-align: left;
    font-size: 0.83rem;
}

.s15-table th {
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #b4bfd5;
    background: #1b2230;
    white-space: nowrap;
}

.s15-table tbody tr:hover td {
    background: #1d2535;
}

.s15-table .is-center {
    text-align: center;
}

.s15-table .is-right {
    text-align: right;
}

.s15-mono {
    font-family: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.76rem;
}

.s15-attachments {
    display: inline-flex;
    gap: 0.35rem;
}

.s15-attachments span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.6rem;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.09rem 0.44rem;
    font-size: 0.66rem;
    font-weight: 700;
}

.s15-attachments .is-on {
    border-color: rgba(96, 165, 250, 0.5);
    color: #bfdbfe;
    background: rgba(30, 64, 175, 0.3);
}

.s15-attachments .is-off {
    border-color: rgba(148, 163, 184, 0.44);
    color: #9ca3af;
    background: rgba(17, 24, 39, 0.36);
}

.s15-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 0.12rem 0.52rem;
    font-size: 0.69rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.s15-pill--success {
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
    background: rgba(22, 101, 52, 0.33);
}

.s15-pill--danger {
    border-color: rgba(248, 113, 113, 0.48);
    color: #fecaca;
    background: rgba(127, 29, 29, 0.34);
}

.s15-pill--neutral {
    border-color: rgba(148, 163, 184, 0.44);
    color: #cbd5e1;
    background: rgba(30, 41, 59, 0.45);
}

.s15-attempts {
    display: block;
    margin-top: 0.15rem;
    color: #8f9bb1;
    font-size: 0.7rem;
}

.s15-failure {
    max-width: 320px;
}

.s15-inline-form {
    display: inline-flex;
}

.s15-action-btn {
    width: 2.1rem;
    height: 2.1rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.s15-action-btn.is-disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.s15-empty-table {
    min-height: 180px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1.2rem;
}

.s15-mobile-list {
    display: none;
}

.s15-mobile-item {
    border-top: 1px solid #2f394d;
    padding: 0.95rem 1.1rem;
    display: grid;
    gap: 0.5rem;
}

.s15-mobile-item__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.s15-mobile-item__title {
    margin: 0;
    color: #e6ebf8;
    font-weight: 600;
}

.s15-pagination {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

body.s13-drawer-open {
    overflow: hidden;
}

.s13-drawer {
    position: fixed;
    inset: 0;
    z-index: 1070;
    pointer-events: none;
}

.s13-drawer.is-open {
    pointer-events: auto;
}

.s13-drawer__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(7, 11, 20, 0.65);
    backdrop-filter: blur(1.5px);
}

.s13-drawer__panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(520px, 92vw);
    border-left: 1px solid #353d4e;
    background: linear-gradient(160deg, #191f2b 0%, #141a27 100%);
    box-shadow: -18px 0 36px rgba(2, 6, 14, 0.46);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.24s ease;
}

.s13-drawer.is-open .s13-drawer__panel {
    transform: translateX(0);
}

.s13-drawer__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.05rem;
    border-bottom: 1px solid #2d3548;
}

.s13-drawer__header h2 {
    margin: 0;
    font-size: 1.08rem;
}

.s13-drawer__header p {
    margin: 0.22rem 0 0;
    color: #9aa7bf;
}

.s13-drawer__close {
    width: 2rem;
    height: 2rem;
    border-radius: 10px;
    border: 1px solid #35405a;
    color: #a9b4c9;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #1d2637;
}

.s13-drawer__close:hover {
    border-color: #4e6388;
    color: #e5ecfb;
}

.s13-drawer__body {
    padding: 1rem 1.05rem;
    display: grid;
    gap: 0.95rem;
    overflow-y: auto;
}

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

.s13-drawer-meta {
    border: 1px solid #2d3548;
    border-radius: 10px;
    background: #1f2838;
    padding: 0.58rem 0.68rem;
    display: grid;
    gap: 0.2rem;
}

.s13-drawer-meta--full {
    grid-column: 1 / -1;
}

.s13-drawer-meta label {
    margin: 0;
    font-size: 0.67rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8f9ab2;
}

.s13-drawer-meta p {
    margin: 0;
    color: #e8eefc;
}

.s13-drawer-block {
    border: 1px solid #2d3548;
    border-radius: 10px;
    background: #1f2838;
    padding: 0.75rem 0.8rem;
    display: grid;
    gap: 0.58rem;
}

.s13-drawer-block h3 {
    margin: 0;
    font-size: 0.89rem;
    color: #e8eefc;
}

.s13-drawer-block p {
    margin: 0;
    color: #c3cde2;
    font-size: 0.82rem;
}

.s13-drawer-block dl {
    margin: 0;
    display: grid;
    gap: 0.3rem;
}

.s13-drawer-block dt {
    color: #8f9ab2;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.s13-drawer-block dd {
    margin: 0;
    color: #d8e2f8;
    font-size: 0.78rem;
}

.s13-drawer-block__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.s13-json {
    margin: 0;
    border-radius: 10px;
    border: 1px solid #2f384d;
    background: #111827;
    color: #d6deed;
    font-size: 0.77rem;
    line-height: 1.45;
    padding: 0.75rem;
    max-height: 280px;
    overflow: auto;
}

@media (max-width: 1180px) {
    .s08-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .s08-alerts-grid {
        grid-template-columns: 1fr;
    }

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

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

    .s15-config-grid {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 760px) {
    .s08-screen.shell {
        width: min(1320px, 97vw);
    }

    .s08-screen__header {
        flex-direction: column;
        gap: 0.7rem;
    }

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

    .s08-table-card__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .s08-table-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .s08-table-wrap {
        display: none;
    }

    .s08-mobile-list {
        display: block;
    }

    .s13-screen.shell {
        width: min(1360px, 97vw);
    }

    .s13-screen__header {
        flex-direction: column;
        gap: 0.7rem;
    }

    .s13-filters-form,
    .s13-summary-grid {
        grid-template-columns: 1fr;
    }

    .s13-filters-actions {
        justify-content: flex-start;
    }

    .s13-table-wrap {
        display: none;
    }

    .s13-mobile-list {
        display: block;
    }

    .s13-table-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .s13-drawer__panel {
        width: 100vw;
    }

    .s13-drawer-meta-grid {
        grid-template-columns: 1fr;
    }

    .s15-screen.shell {
        width: min(1360px, 97vw);
    }

    .s15-screen__header {
        flex-direction: column;
        gap: 0.7rem;
    }

    .s15-form-grid {
        grid-template-columns: 1fr;
    }

    .s15-summary-grid {
        grid-template-columns: 1fr;
    }

    .s15-table-wrap {
        display: none;
    }

    .s15-mobile-list {
        display: block;
    }

    .s15-table-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .s15-table .is-right {
        text-align: left;
    }
}

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

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

    .s12-dentalink-credential-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .s12-screen.shell,
    .s12-form-screen.shell {
        width: min(1320px, 97vw);
    }

    .s12-screen__header,
    .s12-form-screen__header {
        flex-direction: column;
        gap: 0.7rem;
    }

    .s12-filters-form,
    .s12-dentalink-credential-form,
    .s12-form-grid {
        grid-template-columns: 1fr;
    }

    .s12-form-actions,
    .s12-modal-actions,
    .s12-dentalink-credential-actions {
        justify-content: flex-start;
    }

    .s12-checkbox {
        margin-top: 0;
    }

    .s12-table-card__header,
    .s12-table-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .s12-table .is-right {
        text-align: left;
    }

    .s12-actions {
        justify-content: flex-start;
    }
}

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

    .s07-filters-form {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .s07-filters-form--demo {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .s07-advanced-filter__top {
        grid-template-columns: minmax(0, 1fr) minmax(210px, 0.58fr) auto;
    }

    .s07-advanced-filter__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .s07-filter-strip {
        flex-direction: column;
        align-items: stretch;
    }

    .s07-status-tabs {
        margin-left: 0;
    }

    .s07-toolbar-card__header {
        flex-direction: column;
        align-items: stretch;
    }

    .s07-toolbar-card__actions {
        justify-content: flex-end;
    }

    .s07-unified-row__summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .s07-unified-row__actions {
        justify-content: flex-start;
    }

    .s07-unified-row__details {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .s07-profiles-grid,
    .s07-issue-grid,
    .s07-issue-popup-grid,
    .s07-issue-popup-resume-cards {
        grid-template-columns: 1fr;
    }

    .s07-document-banner {
        grid-template-columns: 1fr;
    }

    .s07-issue-modal__panel {
        width: min(1200px, 97vw);
    }
}

@media (max-width: 760px) {
    .s07-screen.shell {
        width: min(1320px, 97vw);
    }

    .s07-filters-form,
    .s07-form-grid {
        grid-template-columns: 1fr;
    }

    .s07-filters-form--demo {
        grid-template-columns: 1fr;
    }

    .s07-advanced-filter__top {
        grid-template-columns: 1fr;
    }

    .s07-advanced-filter__toggle {
        width: 100%;
        justify-content: center;
    }

    .s07-advanced-filter__grid {
        grid-template-columns: 1fr;
    }

    .s07-toolbar-card__actions {
        width: 100%;
        justify-content: space-between;
        flex-wrap: wrap;
    }

    .s07-status-tabs {
        width: 100%;
    }

    .s07-status-tab {
        flex: 1 1 calc(50% - 0.42rem);
        text-align: center;
    }

    .s07-screen__header {
        flex-direction: column;
        gap: 0.7rem;
    }

    .s07-context-card {
        flex-direction: column;
        align-items: stretch;
    }

    .s07-table-card__header,
    .s07-table-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .s07-table .is-right {
        text-align: left;
    }

    .s07-unified-list {
        padding: 0.65rem;
    }

    .s07-unified-row__summary {
        grid-template-columns: minmax(0, 1fr);
        padding: 0.72rem;
    }

    .s07-unified-row__details {
        grid-template-columns: 1fr;
        padding: 0.72rem;
    }

    .s07-actions {
        justify-content: flex-start;
    }

    .s07-action-btn--primary {
        min-width: 0;
        width: auto;
    }

    .s07-issue-modal__panel {
        width: 100vw;
        max-height: 100vh;
        margin: 0;
        border-radius: 0;
        border-left: 0;
        border-right: 0;
    }

    .s07-group-modal__body {
        padding: 0.78rem;
    }

    .s07-group-modal__summary {
        gap: 0.4rem;
    }

    .s07-group-modal__summary,
    .s07-group-modal__total {
        width: 100%;
    }

    .s07-group-modal__total {
        justify-items: start;
    }

    .s07-group-modal__total-value {
        font-size: 1.52rem;
    }

    .s07-group-modal__table-wrap {
        max-height: 132px;
    }

    .s07-group-desglose-list {
        max-height: 238px;
    }

    .s07-group-modal__form {
        padding: 0.72rem;
    }

    .s07-group-modal__form-footer {
        margin: 0 -0.72rem -0.72rem;
        padding: 0.62rem 0.72rem 0.72rem;
        bottom: -0.72rem;
    }

    .s07-group-modal__preview-actions,
    .s07-group-modal__actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .s07-group-modal__preview-actions .btn,
    .s07-group-modal__actions .btn {
        width: 100%;
        justify-content: center;
    }

    .s07-legacy-pdf-modal__body {
        height: calc(100vh - 4rem);
        min-height: 320px;
    }

    .s07-document-file-modal__body {
        height: calc(100vh - 4rem);
        min-height: 320px;
    }

    .s07-issue-popup-card__top {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.72rem;
    }

    .s07-issue-popup-card__meta {
        text-align: left;
    }

    .s07-issue-emitter-trigger {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.42rem;
    }

    .s07-issue-emitter-trigger__badge {
        max-width: 120px;
    }

    .s07-issue-emitter-trigger > i {
        justify-self: end;
    }

    .s07-issue-profile-toggle {
        min-height: 1.9rem;
        padding: 0.24rem 0.58rem;
    }

    .s07-issue-receptor-card__identity {
        align-items: flex-start;
    }

    .s07-issue-receptor-warning {
        flex-direction: column;
    }

    .s07-issue-profile-option {
        grid-template-columns: minmax(0, 1fr);
    }

    .s07-issue-profile-option__status {
        display: none;
    }

    .s07-issue-line-card {
        grid-template-columns: 1fr;
        padding: 0.75rem;
    }

    .s07-issue-line-card__context {
        grid-template-columns: 1fr;
    }

    .s07-issue-line-card__right {
        border-left: 0;
        border-top: 1px solid #2e3a53;
        padding-left: 0;
        padding-top: 0.72rem;
    }

    .s07-issue-line-card__line-total {
        justify-items: start;
    }

    .s07-issue-emitter-option {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .s07-issue-emitter-option__branch {
        max-width: 120px;
    }

    .s07-issue-confirm__dialog {
        padding: 1rem 0.92rem 0.86rem;
        gap: 0.72rem;
    }

    .s07-issue-confirm__dialog h5 {
        font-size: 1.46rem;
    }

    .s07-issue-confirm__actions {
        grid-template-columns: minmax(0, 1fr);
    }

    .s07-issue-confirm__meta {
        flex-direction: column;
        align-items: center;
    }
}

/* Tema global obligatorio: dark mode (fuente nativa por data-theme-version) */
body.admin-shell[data-theme-version="dark"] .admin-custom {
    margin: 0;
    color-scheme: dark;
    color: #d7d9de;
    background: transparent;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .shell.card {
    border-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .section {
    background: #1c2030;
    border-color: #2a3350;
    color: #d7d9de;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcuts-panel {
    background: transparent;
    border: 0;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .title {
    color: #f8fafc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .subtitle,
body.admin-shell[data-theme-version="dark"] .admin-custom .muted {
    color: #a5aab2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .top-nav .nav-link {
    border-color: #3a3a3d;
    background: #272627;
    color: #d0d3da;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .top-nav .nav-link.is-active {
    border-color: rgba(var(--primary-rgb), 0.45);
    background: rgba(var(--primary-rgb), 0.18);
    color: #dbe9ff;
}

body.admin-shell[data-theme-version="dark"] .admin-custom label,
body.admin-shell[data-theme-version="dark"] .admin-custom .subtitle-strong,
body.admin-shell[data-theme-version="dark"] .admin-custom .list {
    color: #d2d5dc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom input[type="text"],
body.admin-shell[data-theme-version="dark"] .admin-custom input[type="number"],
body.admin-shell[data-theme-version="dark"] .admin-custom input[type="email"],
body.admin-shell[data-theme-version="dark"] .admin-custom input[type="password"],
body.admin-shell[data-theme-version="dark"] .admin-custom input[type="file"],
body.admin-shell[data-theme-version="dark"] .admin-custom select,
body.admin-shell[data-theme-version="dark"] .admin-custom textarea {
    border-color: #3a3a3d;
    background: #171617;
    color: #d7d9de;
}

body.admin-shell[data-theme-version="dark"] .admin-custom input:focus,
body.admin-shell[data-theme-version="dark"] .admin-custom select:focus,
body.admin-shell[data-theme-version="dark"] .admin-custom textarea:focus {
    border-color: var(--primary);
    outline: 2px solid rgba(var(--primary-rgb), 0.24);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .sri-config-control > input[readonly],
body.admin-shell[data-theme-version="dark"] .admin-custom .sri-config-control > input:disabled,
body.admin-shell[data-theme-version="dark"] .admin-custom .sri-config-control > select:disabled,
body.admin-shell[data-theme-version="dark"] .admin-custom .sri-config-control.is-locked > input {
    background: #1b2232;
    border-color: #3a4d6d;
    color: #b8c6df;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .s07-filters-form--demo input,
body.admin-shell[data-theme-version="dark"] .admin-custom .s07-filters-form--demo select,
body.admin-shell[data-theme-version="dark"] .admin-custom .s07-page-size-form select {
    border-color: #3a4660;
    background: #1d2534;
    color: #e5ecfb;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .s07-filters-form--demo input::placeholder {
    color: #97a6c0;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .s07-filters-form--demo select option,
body.admin-shell[data-theme-version="dark"] .admin-custom .s07-page-size-form select option {
    background: #1a2130;
    color: #e5ecfb;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .shell .btn-soft {
    background: #252a3a;
    color: #d0d7e8;
    border: 1px solid #2a3350;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .shell .btn-soft:hover {
    background: #2d3347;
    border-color: #374060;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .shell .btn-soft.s07-action-btn--danger {
    border-color: rgba(248, 113, 113, 0.52);
    background: rgba(127, 29, 29, 0.32);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .shell .btn-soft.s07-action-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.7);
    background: rgba(127, 29, 29, 0.46);
    color: #fee2e2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .status {
    background: rgba(22, 101, 52, 0.32);
    border-color: rgba(74, 222, 128, 0.45);
    color: #86efac;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .error-box {
    background: rgba(127, 29, 29, 0.32);
    border-color: rgba(248, 113, 113, 0.5);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .summary-grid,
body.admin-shell[data-theme-version="dark"] .admin-custom .code-details {
    background: #1F2025;
    border-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .factura-visual {
    background: linear-gradient(180deg, #1F2025 0%, #171617 100%);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .factura-table th,
body.admin-shell[data-theme-version="dark"] .admin-custom .factura-table td {
    border-bottom-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .factura-table th {
    background: #272627;
    color: #d2d5dc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-header .subtitle {
    color: #b2b8c2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--teal {
    color: #5eead4;
    background: rgba(94, 234, 212, 0.12);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--blue {
    color: #93c5fd;
    background: rgba(147, 197, 253, 0.12);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--amber {
    color: #fcd34d;
    background: rgba(252, 211, 77, 0.12);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--rose {
    color: #fda4af;
    background: rgba(253, 164, 175, 0.12);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--slate {
    color: #cbd5e1;
    background: rgba(203, 213, 225, 0.1);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-icon--green {
    color: #86efac;
    background: rgba(134, 239, 172, 0.12);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-kpi-card,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-health-card,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-alert-item,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcut-card,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-state-card,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-empty-state {
    border-color: #2a3350;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcuts-title {
    color: #9ca3af;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcut-link {
    background: #1f2025;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcut-link:hover {
    background: #272627;
    border-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcut-icon {
    color: #b8bfcb;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-shortcut-label {
    color: #d7d9de;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-health-card {
    border-left: 3px solid rgba(94, 234, 212, 0.5);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-card-link:hover .dashboard-kpi-card--interactive,
body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-card-link:hover .dashboard-health-card--interactive {
    border-color: rgba(var(--primary-rgb), 0.5);
    box-shadow: 0 12px 28px rgba(var(--primary-rgb), 0.2);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-sparkline span {
    background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.9), rgba(59, 14, 179, 0.85));
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-screen .cert-badge--success,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-screen .cert-badge--success {
    background: rgba(22, 101, 52, 0.36);
    border-color: rgba(74, 222, 128, 0.48);
    color: #86efac;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-screen .cert-badge--danger,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-screen .cert-badge--danger {
    background: rgba(127, 29, 29, 0.4);
    border-color: rgba(248, 113, 113, 0.54);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-screen .cert-badge--warning,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-screen .cert-badge--warning {
    background: rgba(146, 64, 14, 0.4);
    border-color: rgba(252, 211, 77, 0.52);
    color: #fcd34d;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .dashboard-screen .cert-badge--neutral,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-screen .cert-badge--neutral {
    background: rgba(30, 41, 59, 0.45);
    border-color: rgba(148, 163, 184, 0.4);
    color: #cbd5e1;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-card,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-canary__item {
    border-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-screen__eyebrow,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-card__header p,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-plan__updated {
    color: #a5aab2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-table th,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-table td {
    border-bottom-color: #363841;
    color: #d2d5dc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-table th {
    background: #272627;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item {
    border-color: #313848;
    background: #1a1f2b;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item--success {
    border-color: rgba(54, 193, 133, 0.34);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item--danger {
    border-color: rgba(255, 102, 102, 0.32);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item__title {
    color: #d7dce7;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item__meta {
    color: #8f98a8;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-item__runtime-note {
    color: #86efac;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-btn--primary {
    border-color: rgba(var(--primary-rgb), 0.5);
    background: rgba(var(--primary-rgb), 0.2);
    color: #d4b8ff;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-btn--primary:hover {
    border-color: rgba(var(--primary-rgb), 0.65);
    background: rgba(var(--primary-rgb), 0.32);
    color: #ecdcff;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-btn--danger {
    border-color: rgba(248, 113, 113, 0.4);
    background: rgba(127, 29, 29, 0.18);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-installed-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.6);
    background: rgba(127, 29, 29, 0.32);
    color: #fee2e2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-dropzone {
    border-color: #465272;
    background: #151a26;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-dropzone__text {
    color: #8f98a8;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-dropzone__text strong {
    color: #4f36ff;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-action-btn--danger {
    border-color: rgba(248, 113, 113, 0.36);
    background: rgba(127, 29, 29, 0.18);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-action-btn--danger:hover {
    border-color: rgba(248, 113, 113, 0.58);
    background: rgba(127, 29, 29, 0.34);
    color: #fee2e2;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-preview {
    border-color: #3f4b63;
    background: #1a1f2a;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-preview__icon {
    color: #4f36ff;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-preview__name {
    color: #f1f5f9;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-preview__expiry,
body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-meta__row > span {
    color: #8f98a8;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-active-meta__row > strong {
    color: #e7edf9;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-inline-error {
    background: rgba(127, 29, 29, 0.32);
    border-color: rgba(248, 113, 113, 0.5);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .cert-modal .section {
    border-color: #363841;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation,
body.admin-auth-body[data-theme-version="dark"] .authincation {
    background:
        radial-gradient(circle at 10% 10%, rgba(73, 17, 216, 0.2), transparent 30%),
        radial-gradient(circle at 90% 90%, rgba(14, 165, 233, 0.14), transparent 28%),
        #0b1220;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .row,
body.admin-auth-body[data-theme-version="dark"] .authincation .row {
    background: #111827;
    box-shadow: 0 24px 56px rgba(2, 6, 23, 0.6);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-form-column,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-form-column {
    background: #1f2937;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form {
    background: #272627;
    border-color: #334155;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form .title,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form .title {
    color: #f8fafc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form p,
body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form .mb-1,
body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .form-check-label,
body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-template-meta,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form p,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form .mb-1,
body.admin-auth-body[data-theme-version="dark"] .authincation .form-check-label,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-template-meta {
    color: #9fb0cc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form .form-control,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form .form-control {
    background: #0f172a;
    border-color: #334155;
    color: #e2e8f0;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form .form-control::placeholder,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form .form-control::placeholder {
    color: #94a3b8;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .login-form .form-control:focus,
body.admin-auth-body[data-theme-version="dark"] .authincation .login-form .form-control:focus {
    border-color: var(--primary);
    outline: 2px solid rgba(var(--primary-rgb), 0.24);
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-forgot-link,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-forgot-link {
    color: #a78bfa;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-forgot-link:hover,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-forgot-link:hover {
    color: #c4b5fd;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-password-toggle,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-password-toggle {
    color: #a3b1ca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .authincation .auth-password-toggle:hover,
body.admin-auth-body[data-theme-version="dark"] .authincation .auth-password-toggle:hover {
    color: #e2e8f0;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-alert--danger,
body.admin-auth-body[data-theme-version="dark"] .auth-alert--danger {
    background: rgba(127, 29, 29, 0.34);
    border-color: rgba(248, 113, 113, 0.5);
    color: #fecaca;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-alert--warning,
body.admin-auth-body[data-theme-version="dark"] .auth-alert--warning {
    background: rgba(146, 64, 14, 0.26);
    border-color: rgba(251, 191, 36, 0.5);
    color: #fcd34d;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-alert--info,
body.admin-auth-body[data-theme-version="dark"] .auth-alert--info {
    background: rgba(var(--primary-rgb), 0.2);
    border-color: rgba(var(--primary-rgb), 0.45);
    color: #c4b5fd;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-alert--success,
body.admin-auth-body[data-theme-version="dark"] .auth-alert--success {
    background: rgba(6, 95, 70, 0.3);
    border-color: rgba(110, 231, 183, 0.45);
    color: #a7f3d0;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-security-note,
body.admin-auth-body[data-theme-version="dark"] .auth-security-note {
    color: #9fb0cc;
}

body.admin-shell[data-theme-version="dark"] .admin-custom .auth-form-column,
body.admin-auth-body[data-theme-version="dark"] .auth-form-column {
    background: #0f1320;
}

@keyframes auth-spin {
    to {
        transform: rotate(360deg);
    }
}

/* S07 queue visual alignment (pixel pass - 2026-02-24) */
.s07-screen__header {
    margin-bottom: 1.25rem;
}

.s07-screen__header .title {
    margin-bottom: 0.2rem;
}

.s07-kpi-card {
    border-radius: 14px;
    border-color: #2f3748;
    background: linear-gradient(180deg, #202633 0%, #1b2230 100%);
}

.s07-toolbar-card {
    border-radius: 14px;
    border: 1px solid #2f3748;
    background: linear-gradient(180deg, #1c2230 0%, #18202d 100%);
    box-shadow: 0 18px 38px rgba(5, 10, 22, 0.26);
}

.s07-toolbar-card__title h2 {
    font-size: 1.42rem;
}

.s07-filter-strip {
    border-top: 1px solid #2b3343;
    padding-top: 0.8rem;
}

.s07-table-card {
    border: 1px solid #2e3648;
    border-radius: 14px;
    background: linear-gradient(180deg, #1a202b 0%, #161c28 100%);
    box-shadow: 0 20px 40px rgba(4, 8, 18, 0.28);
}

.s07-table-card__header--meta {
    padding: 0.82rem 1rem 0.68rem;
    border-bottom: 1px solid #2b3343;
}

.s07-unified-list {
    gap: 0.62rem;
    padding: 0.72rem;
}

.s07-unified-list-head {
    display: grid;
    grid-template-columns: minmax(360px, 2.45fr) minmax(200px, 1.3fr) minmax(200px, 1.1fr) minmax(120px, 0.75fr) minmax(220px, 1.2fr);
    gap: 0.72rem;
    align-items: center;
    padding: 0.65rem 0.82rem 0.55rem;
    color: #8a94aa;
    font-size: 0.79rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
}

.s07-unified-list-head .is-right {
    text-align: right;
}

.s07-unified-row {
    position: relative;
    border: 1px solid #313a4d;
    border-radius: 12px;
    background: #1a2130;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.s07-unified-row[open] {
    border-color: #44516d;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(79, 120, 208, 0.16);
}

.s07-unified-row[open]::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 3px;
    background: linear-gradient(180deg, #4f78d0 0%, #3e67bd 100%);
}

.s07-unified-row--warning[open] {
    border-color: rgba(217, 153, 53, 0.6);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(217, 153, 53, 0.2);
}

.s07-unified-row--warning[open]::before {
    background: linear-gradient(180deg, #d9a347 0%, #b8872f 100%);
}

.s07-unified-row--danger[open] {
    border-color: rgba(248, 113, 113, 0.55);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(248, 113, 113, 0.19);
}

.s07-unified-row--danger[open]::before {
    background: linear-gradient(180deg, #ef4444 0%, #dc2626 100%);
}

.s07-unified-row--info[open] {
    border-color: rgba(96, 165, 250, 0.6);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(96, 165, 250, 0.2);
}

.s07-unified-row--info[open]::before {
    background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
}

.s07-unified-row--success[open] {
    border-color: rgba(74, 222, 128, 0.52);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(74, 222, 128, 0.17);
}

.s07-unified-row--success[open]::before {
    background: linear-gradient(180deg, #22c55e 0%, #16a34a 100%);
}

.s07-unified-row__summary {
    grid-template-columns: minmax(360px, 2.45fr) minmax(200px, 1.3fr) minmax(200px, 1.1fr) minmax(120px, 0.75fr) minmax(220px, 1.2fr);
    gap: 0.72rem;
    padding: 0.84rem 0.9rem;
}

.s07-unified-row__summary:hover {
    background: #1d2535;
    border-radius: inherit;
}

.s07-unified-row[open] .s07-unified-row__summary {
    border-bottom: 1px solid #2f394d;
    background: #20283a;
}

.s07-unified-row__status,
.s07-unified-row__emission,
.s07-unified-row__amount {
    display: grid;
    gap: 0.16rem;
}

.s07-unified-row__emission > span {
    color: #ebf2ff;
    font-size: 0.82rem;
    font-weight: 700;
}

.s07-unified-row__status small,
.s07-unified-row__emission small {
    color: #9aa8c3;
    font-size: 0.72rem;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.s07-unified-row__emission small i {
    font-size: 0.76rem;
    line-height: 1;
}

.s07-unified-row__status small {
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
}

.s07-unified-row__patient {
    gap: 0.55rem;
}

.s07-row-caret {
    width: 1rem;
    height: 1rem;
    color: #7686a6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.s07-row-caret i {
    font-size: 1rem;
    transition: transform 0.2s ease;
}

.s07-unified-row[open] .s07-row-caret i {
    transform: rotate(180deg);
}

.s07-avatar {
    width: 2rem;
    height: 2rem;
    min-width: 2rem;
    min-height: 2rem;
    border-radius: 50%;
    flex: 0 0 2rem;
}

.s07-unified-row__patient-line strong,
.s07-unified-row__patient-line a {
    font-size: 0.97rem;
    font-weight: 700;
}

.s07-unified-row__patient-copy small {
    margin-top: 0.13rem;
    font-size: 0.71rem;
}

.s07-unified-alias {
    padding: 0.12rem 0.44rem;
    font-size: 0.64rem;
}

.s07-unified-row__amount {
    justify-items: end;
}

.s07-unified-row__amount strong {
    font-size: 1.06rem;
    font-weight: 800;
}

.s07-unified-row__amount small {
    text-align: right;
}

.s07-unified-row__actions {
    justify-content: flex-end;
    gap: 0.38rem;
}

.s07-unified-row__actions .btn {
    min-height: 2.25rem;
    border-radius: 10px;
    padding-inline: 0.82rem;
}

.s07-action-btn--primary,
.s07-action-btn--danger {
    min-width: 6.4rem;
}

.s07-icon-action {
    width: 2rem;
    height: 2rem;
    border-radius: 8px;
    border-color: #3b4760;
    background: #202a3c;
    opacity: 0.92;
}

.s07-icon-action:hover {
    opacity: 1;
}

.s07-icon-action.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

.s07-icon-action.is-loading {
    cursor: progress;
    pointer-events: none;
}

.s07-mail-send-btn {
    width: 100%;
    justify-content: center;
    gap: 0.45rem;
}

.s07-mail-confirm {
    position: fixed;
    inset: 0;
    z-index: 1250;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.s07-mail-confirm.is-open {
    display: flex;
}

.s07-mail-confirm__backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(7, 10, 17, 0.72);
    backdrop-filter: blur(3px);
}

.s07-mail-confirm__dialog {
    position: relative;
    width: min(720px, 94vw);
    border-radius: 16px;
    border: 1px solid #36415a;
    background: #1b2232;
    box-shadow: 0 22px 48px rgba(2, 6, 23, 0.58);
    padding: 1.2rem 1.25rem 1rem;
    text-align: center;
    color: #e6edf8;
    display: grid;
    gap: 0.82rem;
}

.s07-mail-confirm__icon {
    width: 4.7rem;
    height: 4.7rem;
    border-radius: 999px;
    border: 1px solid rgba(59, 130, 246, 0.4);
    background: rgba(30, 64, 175, 0.2);
    color: #60a5fa;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    margin: 0 auto;
}

.s07-mail-confirm__dialog h5 {
    margin: 0;
    color: #f8fafc;
    font-size: 2.05rem;
    line-height: 1.18;
}

.s07-mail-confirm__dialog p {
    margin: 0 auto;
    color: #c5d0e6;
    font-size: 0.95rem;
    line-height: 1.5;
    max-width: 560px;
}

.s07-mail-confirm__email {
    border: 1px solid #33415d;
    border-radius: 12px;
    background: #1a2232;
    color: #dbe6fb;
    font-weight: 700;
    letter-spacing: 0.01em;
    padding: 0.92rem 1rem;
}

.s07-mail-confirm__pending {
    display: grid;
    gap: 0.78rem;
    padding: 0.95rem 1rem;
    border-radius: 14px;
    border: 1px solid rgba(96, 165, 250, 0.28);
    background: linear-gradient(180deg, rgba(19, 30, 47, 0.98) 0%, rgba(15, 24, 39, 0.94) 100%);
    text-align: left;
}

.s07-mail-confirm__pending[hidden] {
    display: none !important;
}

.s07-mail-confirm__pending-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.78rem;
    align-items: flex-start;
}

.s07-mail-confirm__pending-spinner {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(96, 165, 250, 0.12);
    color: #60a5fa;
    font-size: 1.05rem;
}

.s07-mail-confirm__pending-copy {
    display: grid;
    gap: 0.28rem;
}

.s07-mail-confirm__pending-copy strong {
    display: block;
    color: #f8fbff;
    font-size: 0.98rem;
    line-height: 1.4;
}

.s07-mail-confirm__pending-copy p {
    margin: 0;
    max-width: none;
    color: #c6d2e8;
    font-size: 0.9rem;
    line-height: 1.5;
}

.s07-mail-confirm__pending-progress {
    position: relative;
    height: 0.42rem;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(148, 163, 184, 0.16);
}

.s07-mail-confirm__pending-progress::before {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-68%);
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(52, 211, 153, 0) 0%, rgba(96, 165, 250, 0.95) 48%, rgba(129, 140, 248, 0) 100%);
    animation: s07-mail-confirm-progress 1.08s ease-in-out infinite;
}

.s07-mail-confirm__pending-meta {
    color: #8ea1bf;
    font-size: 0.78rem;
    line-height: 1.45;
    letter-spacing: 0.01em;
}

.s07-mail-confirm.is-pending .s07-mail-confirm__icon,
.s07-mail-confirm.is-pending .s07-mail-confirm__dialog > h5,
.s07-mail-confirm.is-pending .s07-mail-confirm__dialog > p,
.s07-mail-confirm.is-pending .s07-mail-confirm__email {
    opacity: 0.56;
}

.s07-mail-confirm__btn-spinner {
    width: 0.96rem;
    height: 0.96rem;
    margin: 0;
}

@keyframes s07-mail-confirm-progress {
    0% {
        transform: translateX(-68%);
    }

    50% {
        transform: translateX(-8%);
    }

    100% {
        transform: translateX(78%);
    }
}

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

.s07-mail-confirm__actions .btn {
    min-height: 3.15rem;
    border-radius: 12px;
    justify-content: center;
    font-size: 1rem;
    gap: 0.4rem;
}

.s07-credit-note-confirm {
    position: fixed;
    inset: 0;
    z-index: 1250;
    display: none;
    align-items: flex-start;
    justify-content: center;
    padding: 1rem;
}

.s07-credit-note-confirm.is-open {
    display: flex;
}

.s07-credit-note-confirm__backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(7, 10, 17, 0.76);
    backdrop-filter: blur(3px);
}

.s07-credit-note-confirm__dialog {
    position: relative;
    width: min(860px, 96vw);
    border-radius: 18px;
    border: 1px solid #36415a;
    background: #1b2232;
    box-shadow: 0 24px 54px rgba(2, 6, 23, 0.58);
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    padding: 0.9rem 1rem 0.85rem;
    color: #e6edf8;
    display: grid;
    gap: 0.7rem;
}

.s07-credit-note-confirm__head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.92rem;
    align-items: start;
}

.s07-credit-note-confirm__icon {
    width: 4rem;
    height: 4rem;
    border-radius: 999px;
    border: 1px solid rgba(248, 113, 113, 0.32);
    background: rgba(127, 29, 29, 0.18);
    color: #fda4af;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
}

.s07-credit-note-confirm__copy h5 {
    margin: 0 0 0.35rem;
    color: #f8fafc;
    font-size: 1.5rem;
    line-height: 1.15;
}

.s07-credit-note-confirm__copy p {
    margin: 0;
    color: #c5d0e6;
    font-size: 0.92rem;
    line-height: 1.5;
}

.s07-credit-note-confirm__body {
    display: grid;
    gap: 0.78rem;
}

.s07-credit-note-confirm__preview-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.s07-credit-note-confirm__preview-actions .btn {
    min-height: 2.8rem;
    border-radius: 12px;
    gap: 0.36rem;
}

.s07-credit-note-confirm__summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.72rem;
}

.s07-credit-note-confirm__block,
.s07-credit-note-confirm__reason {
    border: 1px solid #33415d;
    border-radius: 14px;
    background: rgba(14, 22, 35, 0.72);
    padding: 0.82rem 0.9rem;
    display: grid;
    gap: 0.24rem;
}

.s07-credit-note-confirm__block small,
.s07-credit-note-confirm__reason small,
.s07-credit-note-confirm__meta-row span {
    color: #90a3c4;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.s07-credit-note-confirm__block strong,
.s07-credit-note-confirm__reason strong {
    color: #f8fafc;
    font-size: 1rem;
    line-height: 1.28;
}

.s07-credit-note-confirm__block span,
.s07-credit-note-confirm__meta-row {
    color: #c8d3e8;
    font-size: 0.86rem;
    line-height: 1.4;
}

.s07-credit-note-confirm__table-wrap {
    border: 1px solid #33415d;
    border-radius: 14px;
    overflow: hidden;
    background: rgba(14, 22, 35, 0.72);
}

.s07-credit-note-confirm__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.s07-credit-note-confirm__table th,
.s07-credit-note-confirm__table td {
    padding: 0.72rem 0.82rem;
    border-bottom: 1px solid #2a354b;
    text-align: left;
    vertical-align: top;
}

.s07-credit-note-confirm__table th {
    color: #8ea0bf;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: rgba(18, 26, 44, 0.85);
}

.s07-credit-note-confirm__table td {
    color: #dbe6fb;
}

.s07-credit-note-confirm__table tbody tr:last-child td {
    border-bottom: 0;
}

.s07-credit-note-confirm__table .is-right {
    text-align: right;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

.s07-credit-note-confirm__table .is-empty {
    text-align: center;
    color: #9badcc;
}

.s07-credit-note-confirm__meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 1rem;
    justify-content: space-between;
}

.s07-credit-note-confirm__warning {
    color: #ffd17f !important;
}

.s07-credit-note-confirm__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.78rem;
}

.s07-credit-note-confirm__actions .btn {
    min-height: 3.15rem;
    border-radius: 12px;
    justify-content: center;
    font-size: 1rem;
    gap: 0.4rem;
}

body.s07-credit-note-confirm-open {
    overflow: hidden;
}

.s07-annulment-confirm__dialog {
    width: min(860px, 96vw);
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
}

.s07-annulment-confirm__icon {
    border-color: rgba(251, 191, 36, 0.34);
    background: rgba(120, 53, 15, 0.2);
    color: #fcd34d;
}

.s07-annulment-confirm__eligibility {
    border: 1px solid #33415d;
    border-radius: 14px;
    padding: 0.9rem;
    display: grid;
    gap: 0.75rem;
    background: rgba(14, 22, 35, 0.78);
}

.s07-annulment-confirm__eligibility--success {
    border-color: rgba(74, 222, 128, 0.42);
    background: rgba(17, 94, 89, 0.18);
}

.s07-annulment-confirm__eligibility--warning {
    border-color: rgba(250, 204, 21, 0.34);
    background: rgba(120, 53, 15, 0.2);
}

.s07-annulment-confirm__eligibility--danger {
    border-color: rgba(248, 113, 113, 0.34);
    background: rgba(127, 29, 29, 0.18);
}

.s07-annulment-confirm__eligibility-head,
.s07-annulment-confirm__eligibility-item,
.s07-annulment-confirm__reason-card,
.s07-annulment-confirm__existing-request,
.s07-annulment-confirm__field {
    display: grid;
    gap: 0.26rem;
}

.s07-annulment-confirm__eligibility-head small,
.s07-annulment-confirm__eligibility-item small,
.s07-annulment-confirm__reason-guide small,
.s07-annulment-confirm__existing-request small,
.s07-annulment-confirm__field span:first-child {
    color: #90a3c4;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.s07-annulment-confirm__eligibility-head strong,
.s07-annulment-confirm__eligibility-item strong,
.s07-annulment-confirm__existing-request strong,
.s07-annulment-confirm__reason-card strong {
    color: #f8fafc;
    font-size: 1rem;
    line-height: 1.28;
}

.s07-annulment-confirm__eligibility-head span,
.s07-annulment-confirm__eligibility-item span,
.s07-annulment-confirm__existing-request span,
.s07-annulment-confirm__existing-request p,
.s07-annulment-confirm__reason-card span {
    color: #d3deef;
    font-size: 0.86rem;
    line-height: 1.5;
    margin: 0;
}

.s07-annulment-confirm__eligibility-grid,
.s07-annulment-confirm__reason-grid,
.s07-annulment-confirm__form-grid {
    display: grid;
    gap: 0.72rem;
}

.s07-annulment-confirm__eligibility-grid,
.s07-annulment-confirm__reason-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.s07-annulment-confirm__reason-card,
.s07-annulment-confirm__existing-request {
    border: 1px solid #33415d;
    border-radius: 14px;
    background: rgba(14, 22, 35, 0.72);
    padding: 0.8rem 0.9rem;
}

.s07-annulment-confirm__field select,
.s07-annulment-confirm__field textarea {
    width: 100%;
    border-radius: 12px;
    border: 1px solid #34435f;
    background: #121a27;
    color: #eef4ff;
    padding: 0.85rem 0.95rem;
    font-size: 0.92rem;
}

.s07-annulment-confirm__field textarea {
    resize: vertical;
    min-height: 7rem;
}

.s07-annulment-confirm__field--full {
    grid-column: 1 / -1;
}

.s07-annulment-confirm__check {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: 0.65rem;
    border: 1px solid #33415d;
    border-radius: 14px;
    background: rgba(14, 22, 35, 0.72);
    padding: 0.85rem 0.9rem;
}

.s07-annulment-confirm__check input {
    margin-top: 0.2rem;
}

.s07-annulment-confirm__check span {
    color: #dbe6fb;
    font-size: 0.88rem;
    line-height: 1.45;
}

body.s07-annulment-confirm-open {
    overflow: hidden;
}

.s07-annulment-submit-confirm {
    z-index: 1260;
}

body.s07-annulment-submit-confirm-open {
    overflow: hidden;
}

@media (max-width: 767.98px) {
    .s07-annulment-confirm__eligibility-grid,
    .s07-annulment-confirm__reason-grid,
    .s07-credit-note-confirm__summary,
    .s07-credit-note-confirm__actions {
        grid-template-columns: minmax(0, 1fr);
    }
}

.s07-unified-row__details {
    padding: 0;
    gap: 0;
    background: #151c28;
}

.s07-unified-card {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 1.05rem 1rem 1.1rem;
}

.s07-unified-card + .s07-unified-card {
    border-left: 1px solid #2f394d;
}

.s07-unified-card header h3 {
    font-size: 0.82rem;
    letter-spacing: 0.09em;
    opacity: 0.9;
    display: inline-flex;
    align-items: center;
    gap: 0.36rem;
}

.s07-card-title-icon {
    font-size: 0.9rem;
    color: #8fa4c9;
    opacity: 0.82;
}

.s07-unified-card--receptor header h3 {
    color: #a8bcff;
}

.s07-unified-card--metadata header h3 {
    color: #73c7f0;
}

.s07-unified-card--documents header h3 {
    color: #f2b965;
}

.s07-unified-card dl {
    gap: 0.44rem;
}

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

.s07-detail-grid__item {
    min-width: 0;
    display: grid;
    gap: 0.16rem;
}

.s07-detail-grid__item--span-2 {
    grid-column: 1 / -1;
}

.s07-unified-card dt {
    font-size: 0.71rem;
    color: #8996b2;
}

.s07-unified-card dd {
    font-size: 0.88rem;
    color: #e8efff;
}

.s07-unified-card dd.is-mono {
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
    word-break: break-all;
    letter-spacing: 0.02em;
}

.s07-origin-badge {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    border-radius: 8px;
    border: 1px solid #4b5873;
    background: rgba(38, 48, 69, 0.7);
    color: #dce7ff;
    padding: 0.18rem 0.52rem;
}

.s07-origin-badge i {
    font-size: 0.8rem;
}

.s07-doc-list {
    display: grid;
    gap: 0;
    border-radius: 14px;
    border: 1px solid #324058;
    background: rgba(13, 19, 31, 0.5);
    padding: 0.7rem 0.85rem;
}

.s07-doc-item {
    display: flex;
    justify-content: space-between;
    gap: 0.48rem;
    align-items: center;
    padding: 0.5rem 0;
    border-radius: 0;
    border: 0;
    background: transparent;
}

.s07-doc-item + .s07-doc-item {
    border-top: 1px dashed #31415e;
    padding-top: 0.85rem;
    margin-top: 0.15rem;
}

.s07-doc-item.is-disabled {
    opacity: 0.6;
    border-style: dashed;
}

.s07-doc-item__copy {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.s07-doc-item__icon {
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 10px;
    border: 1px solid #323f59;
    background: rgba(31, 41, 68, 0.75);
    color: #4f72d6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    flex: 0 0 auto;
}

.s07-doc-item.is-disabled .s07-doc-item__icon {
    color: #6d7a95;
    background: rgba(28, 37, 58, 0.62);
}

.s07-doc-item__copy strong {
    display: block;
    color: #edf3ff;
    font-size: 0.98rem;
    line-height: 1.2;
}

.s07-doc-item__copy small {
    display: block;
    color: #92a1bd;
    font-size: 0.82rem;
    line-height: 1.2;
}

.s07-doc-item__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.s07-doc-compliance-note {
    margin-top: 0.9rem;
    border-radius: 12px;
    border: 1px solid rgba(59, 130, 246, 0.42);
    background: rgba(30, 64, 175, 0.15);
    color: #5fa2ff;
    padding: 0.7rem 0.78rem;
    display: inline-flex;
    align-items: flex-start;
    gap: 0.45rem;
    font-size: 0.92rem;
    line-height: 1.35;
}

.s07-doc-compliance-note i {
    margin-top: 0.05rem;
    font-size: 1rem;
}

.s07-unified-doc-note {
    font-size: 0.7rem;
}

.s07-validation-box {
    border-radius: 10px;
    border: 1px solid rgba(217, 153, 53, 0.24);
    background: rgba(19, 25, 37, 0.72);
    padding: 0.65rem 0.72rem;
    display: grid;
    gap: 0.5rem;
}

.s07-validation-item {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 0.42rem;
    font-size: 0.9rem;
    color: #d7e2f7;
}

.s07-validation-item i {
    font-size: 0.92rem;
}

.s07-validation-item.is-ok i {
    color: #22c55e;
}

.s07-validation-item.is-warning i {
    color: #d9a347;
}

.s07-validation-item small {
    flex-basis: 100%;
    margin-left: 1.34rem;
    color: #9fb0cf;
    font-size: 0.74rem;
    line-height: 1.35;
}

.s07-validation-action {
    margin-top: 0.75rem;
    width: 100%;
    min-height: 2.55rem;
    border-radius: 10px;
    border: 1px solid rgba(217, 153, 53, 0.38);
    color: #eab45c;
    background: rgba(17, 23, 35, 0.62);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    font-size: 0.92rem;
    font-weight: 700;
    text-decoration: none;
}

.s07-validation-action:hover {
    color: #f4c977;
    border-color: rgba(217, 153, 53, 0.55);
    background: rgba(22, 30, 46, 0.8);
}

.s07-unified-row--danger .s07-unified-row__emission small {
    color: #f87171;
}

.s07-unified-row--warning .s07-unified-row__emission small {
    color: #fbbf24;
}

.s07-unified-row--info .s07-unified-row__emission small {
    color: #60a5fa;
}

.s07-unified-row--success .s07-unified-row__emission small {
    color: #4ade80;
}

@media (max-width: 1320px) {
    .s07-unified-list-head,
    .s07-unified-row__summary {
        grid-template-columns: minmax(300px, 2fr) minmax(180px, 1.15fr) minmax(170px, 1fr) minmax(105px, 0.7fr) minmax(180px, 1fr);
    }
}

@media (max-width: 1180px) {
    .s07-unified-list-head,
    .s07-unified-row__summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .s07-unified-list-head {
        display: none;
    }

    .s07-unified-row__amount {
        justify-items: start;
    }

    .s07-unified-row__amount small {
        text-align: left;
    }

    .s07-unified-row__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 760px) {
    .s07-unified-row__summary {
        grid-template-columns: minmax(0, 1fr);
        padding: 0.7rem;
    }

    .s07-unified-row__details {
        grid-template-columns: 1fr;
    }

    .s07-unified-card {
        padding: 0.85rem;
    }

    .s07-unified-card + .s07-unified-card {
        border-left: 0;
        border-top: 1px solid #2f394d;
    }

    .s07-detail-grid {
        grid-template-columns: 1fr;
        gap: 0.65rem;
    }

    .s07-detail-grid__item--span-2 {
        grid-column: auto;
    }
}

/* Ambiente operativo: certificacion (tono visual distintivo) */
body.admin-shell.admin-shell--certification {
    background:
        radial-gradient(circle at 10% 10%, rgba(14, 165, 233, 0.14), transparent 34%),
        radial-gradient(circle at 90% 0%, rgba(6, 182, 212, 0.12), transparent 30%),
        #0f1727;
}

body.admin-shell.admin-shell--certification #main-wrapper {
    background: linear-gradient(180deg, #0f192d 0%, #101726 100%);
}

body.admin-shell.admin-shell--certification .nav-header,
body.admin-shell.admin-shell--certification .header,
body.admin-shell.admin-shell--certification .deznav,
body.admin-shell.admin-shell--certification .content-body {
    border-color: rgba(56, 189, 248, 0.26) !important;
}

body.admin-shell.admin-shell--certification .header,
body.admin-shell.admin-shell--certification .nav-header {
    background: linear-gradient(135deg, #082f49, #0c4a6e) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

body.admin-shell.admin-shell--certification .deznav {
    background: linear-gradient(180deg, rgba(9, 25, 41, 0.92), rgba(10, 28, 49, 0.88)) !important;
}

body.admin-shell.admin-shell--certification .admin-custom .shell.card,
body.admin-shell.admin-shell--certification .admin-custom .section,
body.admin-shell.admin-shell--certification .admin-custom .table-card,
body.admin-shell.admin-shell--certification .admin-custom .s07-table-card,
body.admin-shell.admin-shell--certification .admin-custom .s07-toolbar-card {
    border-color: rgba(56, 189, 248, 0.34) !important;
    box-shadow: none !important;
}

body.admin-shell.admin-shell--certification .sri-env-switch {
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.4);
}

@media (max-width: 760px) {
    .s07-mail-confirm__dialog h5 {
        font-size: 1.5rem;
    }

    .s07-mail-confirm__actions {
        grid-template-columns: 1fr;
    }
}

/* S16 Nota de credito */
.s16-screen__header .subtitle {
    max-width: 54rem;
}

.s16-state-card,
.s16-table-card,
.s16-wizard-card,
.s16-timeline-card {
    background: #121a2b;
    border: 1px solid #2c3447;
    border-radius: 1rem;
    padding: 1rem;
}

.s16-table-card__header,
.s16-wizard-card__header,
.s16-timeline-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.9rem;
}

.s16-search-form {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.s16-search-form input {
    min-width: 16rem;
}

.s16-row-actions {
    display: inline-flex;
    gap: 0.45rem;
}

.s16-steps {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.s16-steps li {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    color: #9ea7bb;
}

.s16-steps li span {
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 999px;
    border: 1px solid #3d465b;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
}

.s16-steps li.is-active {
    color: #d7dced;
}

.s16-steps li.is-active span {
    border-color: #3b82f6;
    color: #3b82f6;
}

.s16-wizard-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(15rem, 0.9fr) minmax(0, 1.7fr);
}

.s16-wizard-panel {
    background: #0f1727;
    border: 1px solid #2b3448;
    border-radius: 0.8rem;
    padding: 0.9rem;
}

.s16-wizard-panel h3 {
    font-size: 1rem;
    margin-bottom: 0.75rem;
}

.s16-meta-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.s16-meta-list li {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.45rem 0;
    border-bottom: 1px dashed #2a3245;
}

.s16-meta-list li:last-child {
    border-bottom: 0;
}

.s16-preview-box {
    margin-top: 0.75rem;
    padding: 0.7rem;
    border-radius: 0.7rem;
    border: 1px solid #2f3a53;
    background: #121b2f;
}

.s16-preview-box p {
    margin: 0.2rem 0;
}

.s16-emit-form__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 1rem;
}

.s16-timeline-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
    gap: 0.65rem;
    margin-bottom: 0.8rem;
}

.s16-timeline-summary p {
    margin: 0;
}

.s16-timeline-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.7rem;
}

.s16-timeline-list li {
    display: grid;
    grid-template-columns: 0.9rem 1fr;
    gap: 0.6rem;
    align-items: start;
    padding: 0.55rem 0;
    border-bottom: 1px dashed #2a3243;
}

.s16-timeline-list li:last-child {
    border-bottom: 0;
}

.s16-timeline-dot {
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 999px;
    margin-top: 0.3rem;
    background: #64748b;
}

.s16-timeline-dot.is-ok {
    background: #22c55e;
}

.s16-timeline-dot.is-error {
    background: #ef4444;
}

.s16-timeline-title {
    margin: 0;
    display: flex;
    gap: 0.45rem;
    align-items: center;
}

.s16-timeline-title small {
    color: #93a0b8;
    font-size: 0.72rem;
}

.s16-timeline-message {
    margin: 0.2rem 0 0;
}

@media (max-width: 980px) {
    .s16-wizard-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .s16-table-card__header,
    .s16-wizard-card__header,
    .s16-timeline-card__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .s16-search-form {
        width: 100%;
    }

    .s16-search-form input {
        min-width: 0;
        width: 100%;
    }

    .s16-row-actions {
        flex-wrap: wrap;
        justify-content: flex-end;
    }
}

/* S07 queue visual lock to stitched mock (2026-02-25) */
.s07-toolbar-card {
    border: 1px solid #2a3142;
    border-radius: 14px;
    background: linear-gradient(180deg, #1b2230 0%, #171e2c 100%);
    box-shadow: 0 18px 36px rgba(4, 8, 18, 0.28);
    overflow: hidden;
    padding: 0;
}

.s07-toolbar-card__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    margin-bottom: 0;
    width: 100%;
}

.s07-toolbar-card__controls {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 0.9rem;
    width: 100%;
}

.s07-toolbar-card__controls .s07-filters-form--advanced {
    flex: 1 1 auto;
    margin: 0;
    width: 100%;
    max-width: none;
}

.s07-toolbar-card__controls .s07-advanced-filter__top {
    grid-template-columns: minmax(320px, 1fr) auto;
    gap: 0.7rem;
}

.s07-toolbar-card__controls .s07-advanced-filter__search .s07-smart-search,
.s07-toolbar-card__controls .s07-advanced-filter__toggle {
    min-height: 2.9rem;
    border-radius: 10px;
    border: 1px solid #31394b;
    background: #1a2231;
    color: #d8e1f2;
}

.s07-toolbar-card__controls .s07-advanced-filter__search .s07-smart-search input[type="text"] {
    font-size: 0.99rem;
}

.s07-toolbar-card__controls .s07-advanced-filter__search .s07-smart-search input[type="text"]::placeholder {
    color: #8e9cb6;
}

.s07-toolbar-card .s07-status-tabs {
    display: flex;
    align-items: center;
    gap: 1.7rem;
    padding: 0 0.95rem;
    border-top: 1px solid #2c3448;
    overflow-x: auto;
    margin-left: 0;
    width: 100%;
    min-height: 3.35rem;
}

.s07-toolbar-card .s07-status-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.52rem;
    min-height: 3.35rem;
    padding: 0 0.08rem;
    border-bottom: 3px solid transparent;
    color: #99a6bc !important;
    font-size: 0.98rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    white-space: nowrap;
    border: 0;
    background: transparent;
    border-radius: 0;
}

.s07-toolbar-card .s07-status-tab:hover {
    color: #dce5f7 !important;
}

.s07-toolbar-card .s07-status-tab.is-active {
    color: #eef3ff !important;
    background: transparent;
    border-color: transparent;
    border-bottom-color: #5d5af7;
    box-shadow: none;
}

.s07-toolbar-card .s07-status-tab__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    padding: 0.1rem 0.34rem;
    border-radius: 999px;
    background: rgba(71, 82, 102, 0.44);
    color: #8fa0ba;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
}

.s07-toolbar-card .s07-status-tab.is-active .s07-status-tab__count {
    background: rgba(100, 95, 247, 0.36);
    color: #ecebff;
}

.s07-toolbar-card .s07-status-tab[data-status="error"]:not(.is-active) .s07-status-tab__count {
    background: rgba(171, 64, 82, 0.2);
    color: #ef788f;
}

.s07-toolbar-card .s07-status-tab[data-status="error"].is-active .s07-status-tab__count {
    background: rgba(171, 64, 82, 0.34);
    color: #ffd4dd;
}

.s07-table-card {
    margin-top: 1.05rem;
    border: 1px solid #293245;
    border-radius: 14px;
    background: linear-gradient(180deg, #141b28 0%, #121826 100%);
}

.s07-table-card.is-menu-open {
    overflow: visible;
}

.s07-unified-list {
    gap: 0.75rem;
    padding: 0.8rem;
}

.s07-unified-list-head {
    padding: 0.65rem 0.82rem 0.55rem;
    color: #8c97ac;
    font-size: 0.74rem;
    letter-spacing: 0.08em;
}

.s07-table-wrap.is-menu-open {
    overflow: visible;
}

.s07-unified-row {
    border: 1px solid #2f3950;
    border-radius: 10px;
    background: #1b2331;
    position: relative;
    overflow: hidden;
}

.s07-unified-row[open] {
    border-color: rgba(81, 68, 202, 0.85);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.02),
        0 0 0 1px rgba(81, 68, 202, 0.24);
    z-index: 6;
}

.s07-unified-row.is-menu-open {
    z-index: 7;
    overflow: visible;
}

.s07-unified-row[open]::before {
    display: none;
}

.s07-unified-row__summary {
    padding: 0.94rem 0.95rem;
}

.s07-unified-row:not([open]) > summary,
.s07-unified-row:not([open]) .s07-unified-row__summary {
    border-radius: inherit;
}

.s07-unified-row[open] .s07-unified-row__summary {
    border-bottom: 1px solid #2f3a52;
    background: #1f2737;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.s07-avatar {
    width: 2.12rem;
    height: 2.12rem;
    min-width: 2.12rem;
    min-height: 2.12rem;
    border-radius: 50%;
    flex: 0 0 2.12rem;
    font-weight: 800;
}

.s07-unified-row__patient-line strong,
.s07-unified-row__patient-line a {
    font-size: 1.02rem;
    color: #edf3ff;
}

.s07-unified-row__patient-copy small {
    color: #93a2ba;
}

.s07-unified-row__status small,
.s07-unified-row__emission small,
.s07-unified-row__amount small {
    color: #8fa0ba;
}

.s07-unified-row__amount strong {
    font-size: 1.9rem;
    line-height: 1;
}

.s07-unified-row__actions {
    justify-content: flex-end;
    gap: 0.28rem;
}

.s07-row-action-stack {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
    position: relative;
}

.s07-row-main-action {
    min-width: 7rem;
    min-height: 2.2rem;
    border-radius: 10px;
    border: 1px solid #4a3ada;
    background: linear-gradient(180deg, #5633f2 0%, #3f24cf 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    color: #f5f4ff;
    font-size: 0.82rem;
    font-weight: 680;
    letter-spacing: 0.01em;
    text-decoration: none;
    padding: 0.38rem 0.72rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.38rem;
    white-space: nowrap;
}

.s07-row-main-action i {
    font-size: 0.84rem;
}

.s07-row-main-action span {
    line-height: 1;
}

.s07-row-main-action.is-view {
    border-color: #366edb;
    background: linear-gradient(180deg, #3e80f5 0%, #2f69dd 100%);
    min-width: 5.5rem;
}

.s07-row-main-action.is-retry {
    border-color: #7f8aa1;
    background: linear-gradient(180deg, #47546c 0%, #3c475b 100%);
    min-width: 6.2rem;
}

.s07-row-main-action.is-disabled {
    border-color: #3b475f;
    background: linear-gradient(180deg, #2b3448 0%, #253042 100%);
    color: #8898b5;
    cursor: not-allowed;
}

.s07-row-menu {
    position: relative;
}

.s07-row-menu.is-open {
    z-index: 1260;
}

.s07-row-menu__toggle {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 10px;
    border: 1px solid #36435a;
    background: #252e40;
    color: #a9b6cd;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.s07-row-menu__toggle:hover {
    border-color: #415070;
    color: #dce6f7;
    background: #2a364c;
}

.s07-row-menu__panel {
    position: absolute;
    top: auto;
    bottom: calc(100% + 0.42rem);
    right: 0;
    width: 15.5rem;
    border-radius: 12px;
    border: 1px solid #313f57;
    background: #1f2736;
    box-shadow: 0 16px 34px rgba(6, 11, 24, 0.5);
    padding: 0.44rem 0.38rem;
    display: grid;
    gap: 0.18rem;
    z-index: 1200;
}

.s07-row-menu.is-open-down .s07-row-menu__panel {
    top: calc(100% + 0.42rem);
    bottom: auto;
}

.s07-row-menu__panel[hidden] {
    display: none !important;
}

.s07-row-menu__panel form {
    margin: 0;
}

.s07-row-menu__item {
    width: 100%;
    min-height: 2.08rem;
    border-radius: 9px;
    border: 1px solid transparent;
    background: transparent;
    color: #c9d3e5;
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.42rem 0.56rem;
    display: inline-flex;
    align-items: center;
    gap: 0.48rem;
    cursor: pointer;
}

.s07-row-menu__item i {
    width: 1rem;
    text-align: center;
    color: #9aa7be;
    font-size: 0.92rem;
}

.s07-row-menu__item:hover {
    border-color: #3a4962;
    background: #283246;
    color: #e8eeff;
}

.s07-row-menu__item:hover i {
    color: #d8e2f8;
}

.s07-row-menu__item.is-danger {
    color: #ff6f74;
}

.s07-row-menu__item.is-danger i {
    color: #ff6f74;
}

.s07-row-menu__item.is-danger:hover {
    border-color: rgba(255, 111, 116, 0.35);
    background: rgba(154, 45, 58, 0.24);
}

.s07-row-menu__item.is-disabled {
    opacity: 0.52;
    cursor: not-allowed;
    pointer-events: none;
}

.s07-row-menu__divider {
    display: block;
    width: calc(100% - 0.7rem);
    margin: 0.2rem auto;
    border-top: 1px solid #33415a;
}

.s07-deadline-ring {
    width: 90px;
    margin: 0.5rem auto 0.75rem;
    display: grid;
    justify-items: center;
    gap: 0.42rem;
}

.s07-deadline-ring[hidden] {
    display: none !important;
}

.s07-deadline-ring__chart {
    position: relative;
    width: 90px;
    height: 90px;
}

.s07-deadline-ring__chart svg {
    width: 90px;
    height: 90px;
    transform: rotate(-90deg);
    overflow: visible;
}

.s07-deadline-ring__track,
.s07-deadline-ring__progress {
    fill: none;
    stroke-width: 8;
    stroke-linecap: round;
    transform-origin: 45px 45px;
}

.s07-deadline-ring__track {
    stroke: rgba(255, 255, 255, 0.1);
}

.s07-deadline-ring__progress {
    transition: stroke-dashoffset 600ms ease-out, stroke 200ms ease-out;
}

.s07-deadline-ring__center {
    position: absolute;
    inset: 0;
    display: grid;
    place-content: center;
    text-align: center;
    gap: 0.08rem;
}

.s07-deadline-ring__center strong {
    color: #eef4ff;
    font-size: 1rem;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.s07-deadline-ring__center span {
    color: #93a4c1;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.s07-deadline-ring__status {
    position: absolute;
    left: 50%;
    bottom: 4px;
    transform: translateX(-50%);
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 999px;
    border: 1px solid rgba(99, 102, 241, 0.28);
    background: #131c2d;
    color: #dbe6fb;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    box-shadow: 0 4px 10px rgba(6, 11, 24, 0.34);
}

.s07-deadline-ring__label {
    color: #a7b5cd;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    text-align: center;
    line-height: 1.3;
}

.s07-icon-action {
    width: 2rem;
    height: 2rem;
    border-radius: 8px;
    border: 1px solid transparent;
    background: transparent;
    color: #93a1b9;
}

.s07-icon-action:hover {
    color: #d7e2f7;
    border-color: #34435f;
    background: #222c3f;
}

.s07-icon-action.s07-icon-action--primary {
    color: #23a2ff;
}

.s07-icon-action.s07-icon-action--danger,
.s07-icon-action.is-danger {
    color: #ff6d6d;
}

.s07-icon-action.is-neutral {
    color: #95a4be;
}

.s07-unified-row__details {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    background: #181f2c;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    overflow: hidden;
}

.s07-unified-row__details-primary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.s07-unified-card {
    border: 1px solid #2d374d;
    border-radius: 10px;
    background: #1c2433;
    padding: 0.9rem;
}

.s07-unified-card + .s07-unified-card {
    border-left: 1px solid #2d374d;
    margin-top: 0;
}

.s07-unified-card--group-trace {
    width: 100%;
}

.s07-unified-card header h3 {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
}

.s07-detail-grid {
    gap: 0.72rem 0.9rem;
}

.s07-unified-card dt {
    font-size: 0.69rem;
    color: #8694af;
}

.s07-unified-card dd {
    color: #e9f1ff;
}

.s07-doc-list {
    border: 1px solid #36445f;
    border-radius: 10px;
    padding: 0.6rem 0.7rem;
    background: rgba(15, 22, 36, 0.72);
}

.s07-doc-item {
    gap: 0.6rem;
}

.s07-doc-item.is-disabled {
    opacity: 0.88;
}

.s07-doc-item__copy {
    gap: 0.5rem;
}

.s07-doc-item__icon {
    width: 2rem;
    height: 2rem;
    border-radius: 7px;
    font-size: 1rem;
}

.s07-doc-item__copy strong {
    font-size: 0.96rem;
}

.s07-doc-item__copy small {
    font-size: 0.79rem;
}

.s07-doc-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.12rem 0.4rem;
    border-radius: 6px;
    border: 1px solid #39465f;
    background: #28344a;
    color: #aab8d1;
    font-size: 0.7rem;
    font-weight: 700;
    margin-left: 0.25rem;
}

.s07-doc-status-pill.is-success {
    border-color: rgba(74, 222, 128, 0.45);
    background: rgba(21, 128, 61, 0.2);
    color: #86efac;
}

.s07-doc-generate-form {
    width: 100%;
}

.s07-doc-generate-btn {
    width: 100%;
    min-height: 2.1rem;
    border-radius: 8px;
    border: 1px solid #44557a;
    background: #243149;
    color: #d8e4fb;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    font-weight: 700;
}

.s07-doc-generate-btn:hover {
    border-color: #526693;
    background: #2a3954;
}

.s07-table-card__footer {
    border-top: 1px solid #2b3447;
    padding: 0.82rem 1rem;
}

.s07-table-card__footer .muted {
    font-size: 0.92rem;
}

@media (max-width: 1320px) {
    .s07-toolbar-card__controls .s07-advanced-filter__top {
        grid-template-columns: minmax(260px, 1fr) auto;
    }
}

@media (max-width: 1080px) {
    .s07-toolbar-card__controls {
        flex-wrap: wrap;
    }

    .s07-row-main-action {
        min-width: 6.8rem;
    }

    .s07-unified-row__details-primary {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .s07-toolbar-card__controls {
        padding: 0.7rem;
    }

    .s07-toolbar-card__controls .s07-advanced-filter__top {
        grid-template-columns: 1fr;
    }

    .s07-status-tabs {
        gap: 1rem;
    }

    .s07-unified-row__summary {
        grid-template-columns: minmax(0, 1fr);
    }

    .s07-unified-row__actions {
        justify-content: flex-start;
    }

    .s07-row-main-action {
        min-width: 6.4rem;
        min-height: 2.05rem;
        font-size: 0.8rem;
    }

    .s07-row-menu__toggle {
        height: 2.05rem;
        width: 2.05rem;
    }

    .s07-row-menu__panel {
        width: min(14rem, 82vw);
    }
}

/* S07 multi-pago - Fase 4 */
.s07-unified-list-head,
.s07-unified-row__summary {
    grid-template-columns: minmax(300px, 2.2fr) minmax(125px, 0.9fr) minmax(150px, 1.05fr) minmax(150px, 0.95fr) minmax(120px, 0.8fr) minmax(250px, 1.4fr);
}

.s07-row-select {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.32rem;
    height: 1.32rem;
    border-radius: 0.4rem;
    cursor: pointer;
    flex: 0 0 auto;
}

.s07-row-select__checkbox {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.s07-row-select__control {
    width: 1.04rem;
    height: 1.04rem;
    border-radius: 0.34rem;
    border: 1px solid #4a5a7a;
    background: #1f293b;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.s07-row-select__control::after {
    content: "";
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 0.18rem;
    background: transparent;
    transition: background-color 0.2s ease;
}

.s07-row-select__checkbox:checked + .s07-row-select__control {
    border-color: rgba(99, 102, 241, 0.8);
    background: rgba(67, 56, 202, 0.24);
}

.s07-row-select__checkbox:checked + .s07-row-select__control::after {
    background: #a5b4fc;
}

.s07-unified-row__refs {
    display: grid;
    gap: 0.16rem;
    min-width: 0;
}

.s07-unified-row__refs > span {
    color: #d8e3f7;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.76rem;
    font-weight: 650;
}

.s07-unified-row__refs > small {
    color: #93a2ba;
    font-size: 0.72rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.s07-group-bar {
    margin-top: 0.82rem;
    border: 1px solid #304160;
    border-radius: 12px;
    background: linear-gradient(180deg, #182334 0%, #141d2b 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 0.76rem 0.9rem;
}

.s07-group-bar__meta {
    display: grid;
    gap: 0.1rem;
}

.s07-group-bar__title {
    margin: 0;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8fa0ba;
}

.s07-group-bar__summary {
    margin: 0;
    color: #d8e4f9;
    font-size: 0.92rem;
}

.s07-group-bar__warning {
    margin: 0.15rem 0 0;
    color: #ffd4dc;
    font-size: 0.79rem;
}

.s07-group-bar__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.52rem;
}

.s07-group-modal__panel {
    width: min(1420px, 98vw);
    max-height: calc(100vh - 1.2rem);
    margin: 0.6rem auto;
    border-radius: 16px;
}

.s07-group-modal__body {
    padding: 0;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 0;
    height: min(920px, calc(100vh - 1.2rem));
    max-height: calc(100vh - 1.2rem);
    overflow: hidden;
}

.s07-group-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 0.92rem 1.1rem;
    border-bottom: 1px solid #2d3a53;
    background: #182234;
}

.s07-group-modal__header h2 {
    margin: 0;
    font-size: 1.18rem;
}

.s07-group-modal__body > p.muted {
    margin: 0;
    padding: 0.76rem 1.1rem 0.24rem;
    color: #9aa9c2;
}

.s07-group-modal__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.7rem;
    color: #c9d7ef;
    font-size: 0.84rem;
    padding: 0 1.1rem 0.8rem;
    border-bottom: 1px solid #2b364d;
    background: #141d2c;
}

.s07-group-modal__count {
    color: #d7e4fa;
    font-size: 0.92rem;
}

.s07-group-modal__count strong {
    color: #ffffff;
    font-size: 1.08rem;
    font-weight: 800;
}

.s07-group-modal__total {
    display: grid;
    justify-items: end;
    gap: 0.12rem;
    padding: 0.46rem 0.72rem;
    border: 1px solid rgba(86, 117, 188, 0.72);
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(37, 58, 97, 0.48) 0%, rgba(18, 31, 57, 0.78) 100%);
}

.s07-group-modal__total-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #9db3dc;
}

.s07-group-modal__total-value {
    color: #f8fbff;
    font-size: clamp(1.28rem, 2.2vw, 1.9rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.01em;
}

.s07-group-modal__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(330px, 0.65fr);
    gap: 1rem;
    min-height: 0;
    align-items: stretch;
    overflow: hidden;
    padding: 0.95rem 1.1rem 0.8rem;
}

.s07-group-modal__main {
    display: grid;
    gap: 0.86rem;
    min-width: 0;
    min-height: 0;
    border: 1px solid #31415e;
    border-radius: 12px;
    background: #141e2e;
    padding: 0.82rem;
    overflow: auto;
}

.s07-group-modal__table-wrap {
    border: 1px solid #31415e;
    border-radius: 10px;
    overflow: auto;
    max-height: none;
    min-height: 164px;
}

.s07-group-modal__table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.s07-group-modal__table th,
.s07-group-modal__table td {
    padding: 0.55rem 0.62rem;
    border-bottom: 1px solid #2a354b;
    font-size: 0.78rem;
    color: #d6e2f7;
    text-align: left;
}

.s07-group-modal__table th {
    color: #90a0bb;
    font-size: 0.7rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    background: #1a2538;
}

.s07-group-modal__table th:nth-child(1),
.s07-group-modal__table td:nth-child(1) {
    width: 96px;
    white-space: nowrap;
}

.s07-group-modal__table th:nth-child(2),
.s07-group-modal__table td:nth-child(2) {
    width: 96px;
    white-space: nowrap;
}

.s07-group-modal__table th:nth-child(3),
.s07-group-modal__table td:nth-child(3) {
    width: auto;
}

.s07-group-modal__table th:nth-child(4),
.s07-group-modal__table td:nth-child(4) {
    width: 130px;
    white-space: nowrap;
}

.s07-group-modal__table th.is-right,
.s07-group-modal__table td.is-right {
    text-align: right;
}

.s07-group-modal__desglose {
    display: grid;
    gap: 0.52rem;
}

.s07-group-modal__desglose h3 {
    margin: 0;
}

.s07-group-desglose-list {
    max-height: none;
    overflow: auto;
    border: 1px solid #31415e;
    border-radius: 10px;
    background: #141e2e;
}

.s07-group-modal__form {
    display: grid;
    gap: 0.68rem;
    align-content: start;
    border: 1px solid #31415e;
    border-radius: 10px;
    background: #151f30;
    padding: 0.9rem;
    min-height: 0;
    overflow: auto;
}

.s07-group-modal__form .field {
    display: grid;
    gap: 0.24rem;
}

.s07-group-modal__footer {
    border-top: 1px solid #2d3a53;
    background: #1a2333;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.78rem 1.1rem;
}

.s07-group-modal__footer-totals {
    display: inline-grid;
    gap: 0.1rem;
    align-content: center;
}

.s07-group-modal__footer-totals small {
    color: #93a6c9;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.67rem;
    font-weight: 700;
}

.s07-group-modal__footer-totals strong {
    color: #f8fbff;
    font-size: 1.52rem;
    line-height: 1;
    font-weight: 900;
}

.s07-group-modal__footer-totals span {
    color: #b8c7e3;
    font-size: 0.82rem;
}

.s07-group-modal__footer-actions {
    display: flex;
    justify-content: flex-end;
    width: 100%;
}

.s07-group-modal__preview-actions {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
    margin-right: auto;
    align-items: center;
}

.s07-group-modal__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
    flex-wrap: wrap;
    width: 100%;
}

@media (max-width: 1200px) {
    .s07-unified-list-head,
    .s07-unified-row__summary {
        grid-template-columns: minmax(240px, 2.1fr) minmax(105px, 0.85fr) minmax(130px, 1fr) minmax(130px, 0.9fr) minmax(105px, 0.7fr) minmax(220px, 1.2fr);
    }

    .s07-group-modal__layout {
        grid-template-columns: minmax(0, 1fr);
        padding: 0.86rem 0.95rem 0.95rem;
    }

    .s07-group-modal__main,
    .s07-group-modal__form {
        max-height: 40vh;
    }

    .s07-group-modal__footer {
        padding: 0.72rem 0.95rem;
    }
}

@media (max-width: 992px) {
    .s07-unified-list-head {
        display: none;
    }

    .s07-unified-row__summary {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 0.72rem;
    }

    .s07-unified-row__patient {
        grid-column: 1 / -1;
    }

    .s07-unified-row__refs {
        grid-column: 1 / 2;
    }

    .s07-unified-row__status {
        grid-column: 2 / 3;
    }

    .s07-unified-row__emission,
    .s07-unified-row__amount,
    .s07-unified-row__actions {
        grid-column: 1 / -1;
    }

    .s07-group-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .s07-group-bar__actions {
        justify-content: flex-end;
    }

    .s07-group-modal__panel {
        width: min(1280px, 98vw);
    }

    .s07-group-modal__body {
        height: calc(100vh - 1.2rem);
    }

    .s07-group-modal__layout {
        padding: 0.76rem 0.82rem 0.86rem;
    }

    .s07-group-modal__main,
    .s07-group-modal__form {
        max-height: 38vh;
    }

    .s07-group-modal__footer {
        flex-direction: column;
        align-items: stretch;
        padding: 0.7rem 0.82rem;
    }

    .s07-group-modal__footer-actions {
        width: 100%;
    }

    .s07-group-modal__preview-actions,
    .s07-group-modal__actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .s07-group-modal__preview-actions .btn,
    .s07-group-modal__actions .btn {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 760px) {
    .s07-group-modal__panel {
        width: 100vw;
        max-height: 100vh;
        margin: 0;
        border-radius: 0;
        border-left: 0;
        border-right: 0;
    }

    .s07-group-modal__body {
        height: 100vh;
        max-height: 100vh;
    }

    .s07-group-modal__header {
        padding: 0.74rem 0.78rem;
    }

    .s07-group-modal__body > p.muted {
        padding: 0.62rem 0.78rem 0.2rem;
        font-size: 0.86rem;
    }

    .s07-group-modal__summary {
        padding: 0 0.78rem 0.64rem;
        gap: 0.42rem;
    }

    .s07-group-modal__summary,
    .s07-group-modal__total {
        width: 100%;
    }

    .s07-group-modal__total {
        justify-items: start;
    }

    .s07-group-modal__total-value {
        font-size: 1.46rem;
    }

    .s07-group-modal__layout {
        padding: 0.68rem;
        gap: 0.68rem;
    }

    .s07-group-modal__main {
        padding: 0.66rem;
    }

    .s07-group-modal__form {
        padding: 0.7rem;
    }

    .s07-group-modal__main,
    .s07-group-modal__form {
        max-height: 34vh;
    }

    .s07-group-modal__footer {
        padding: 0.62rem 0.68rem;
        gap: 0.58rem;
    }

    .s07-group-modal__footer-totals strong {
        font-size: 1.34rem;
    }
}
