@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');
@import url("edeclara-theme.css");
@import url('profile-shared.css');
:root {
    --n-blue: #006bb5;
    --n-blue-dark: #004a7c;
    --n-blue-soft: #eaf4fb;
    --n-app-bg: #eef4fb;
    --n-surface: #ffffff;
    --n-surface-alt: #f8fbfe;
    --n-border: #d7e4f0;
    --n-border-strong: #bfd7ea;
    --n-text: #16324a;
    --n-text-muted: #6b7c93;
    --n-success-bg: #dff5e8;
    --n-success-text: #17653f;
    --n-danger-bg: #fde6e7;
    --n-danger-text: #b02a37;
    --n-primary-bg: #e3f1fb;
    --n-primary-text: #0b5f96;
    --n-secondary-bg: #edf2f7;
    --n-secondary-text: #526274;
    --n-shell-shadow: 0 20px 45px rgba(15, 23, 42, 0.08);
    --n-btn-height: 46px;
    --n-btn-height-compact: 40px;
    --n-btn-radius: 16px;
    --n-btn-radius-compact: 14px;
    --n-btn-gap: 0.55rem;
    --n-action-size: 36px;
    --n-action-radius: 0.65rem;
    --n-action-view-bg: rgba(13, 110, 253, 0.12);
    --n-action-view-color: #0d6efd;
    --n-action-edit-bg: rgba(25, 135, 84, 0.12);
    --n-action-edit-color: #198754;
    --n-action-delete-bg: rgba(220, 53, 69, 0.12);
    --n-action-delete-color: #dc3545;
}

html,
body {
    min-height: 100%;
    width: 100%;
    max-width: 100%;
}

html {
    scrollbar-gutter: stable;
}

body {
    margin: 0;
    font-family: 'Montserrat', sans-serif;
    color: var(--n-text);
    background:
        radial-gradient(circle at top right, rgba(0, 107, 181, 0.1), transparent 30%),
        linear-gradient(180deg, #f8fbff 0%, var(--n-app-bg) 100%);
    overflow-x: hidden;
}

html.n-body-scroll-locked,
body.n-body-scroll-locked {
    overflow: hidden;
    overscroll-behavior: none;
}

body.n-body-scroll-locked .tutorial-overlay,
body.n-body-scroll-locked .tutorial-fab {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

* {
    box-sizing: border-box;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 107, 181, 0.35) transparent;
}

*::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

*::-webkit-scrollbar-thumb {
    background-color: rgba(0, 107, 181, 0.3);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

*::-webkit-scrollbar-track {
    background: transparent;
}

a {
    color: inherit;
}

::selection {
    background: rgba(0, 107, 181, 0.16);
    color: var(--n-text);
}

.badge {
    font-weight: 600;
    letter-spacing: 0.01em;
}

.bg-success-subtle {
    background-color: var(--n-success-bg) !important;
    color: var(--n-success-text) !important;
}

.bg-danger-subtle {
    background-color: var(--n-danger-bg) !important;
    color: var(--n-danger-text) !important;
}

.bg-primary-subtle {
    background-color: var(--n-primary-bg) !important;
    color: var(--n-primary-text) !important;
}

.bg-secondary-subtle {
    background-color: var(--n-secondary-bg) !important;
    color: var(--n-secondary-text) !important;
}

button.n-btn-primary,
a.n-btn-primary,
input.n-btn-primary[type="button"],
input.n-btn-primary[type="submit"] {
    color: #ffffff !important;
    background-color: var(--n-blue) !important;
    background-image: linear-gradient(135deg, var(--n-blue) 0%, #0284c7 100%) !important;
    border-color: transparent !important;
    -webkit-appearance: none;
    appearance: none;
}

button.n-btn-primary:hover:not(:disabled),
button.n-btn-primary:focus-visible:not(:disabled),
a.n-btn-primary:hover,
a.n-btn-primary:focus-visible,
input.n-btn-primary[type="button"]:hover:not(:disabled),
input.n-btn-primary[type="button"]:focus-visible:not(:disabled),
input.n-btn-primary[type="submit"]:hover:not(:disabled),
input.n-btn-primary[type="submit"]:focus-visible:not(:disabled) {
    color: #ffffff !important;
    background-color: var(--n-blue-dark) !important;
    background-image: linear-gradient(135deg, var(--n-blue-dark) 0%, var(--n-blue) 100%) !important;
    border-color: var(--n-blue-dark) !important;
    text-decoration: none !important;
}

/* Unified button system */
button.primary-btn,
a.primary-btn,
button.config-primary-btn,
a.config-primary-btn,
button.refresh-btn,
a.refresh-btn,
button.n-btn-primary,
a.n-btn-primary,
input.n-btn-primary[type="button"],
input.n-btn-primary[type="submit"],
button.btn.btn-primary,
a.btn.btn-primary,
button.btn.btn-success,
a.btn.btn-success {
    min-height: var(--n-btn-height) !important;
    padding: 0 1rem !important;
    border: 0 !important;
    border-radius: var(--n-btn-radius) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--n-btn-gap) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    color: #ffffff !important;
    background-color: var(--n-blue) !important;
    background-image: linear-gradient(135deg, var(--n-blue) 0%, #2793d4 100%) !important;
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.18) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease !important;
    -webkit-appearance: none;
    appearance: none;
}

button.primary-btn:hover:not(:disabled),
button.primary-btn:focus-visible:not(:disabled),
a.primary-btn:hover,
a.primary-btn:focus-visible,
button.config-primary-btn:hover:not(:disabled),
button.config-primary-btn:focus-visible:not(:disabled),
button.refresh-btn:hover:not(:disabled),
button.refresh-btn:focus-visible:not(:disabled),
button.n-btn-primary:hover:not(:disabled),
button.n-btn-primary:focus-visible:not(:disabled),
a.n-btn-primary:hover,
a.n-btn-primary:focus-visible,
input.n-btn-primary[type="button"]:hover:not(:disabled),
input.n-btn-primary[type="button"]:focus-visible:not(:disabled),
input.n-btn-primary[type="submit"]:hover:not(:disabled),
input.n-btn-primary[type="submit"]:focus-visible:not(:disabled),
button.btn.btn-primary:hover:not(:disabled),
button.btn.btn-primary:focus-visible:not(:disabled),
a.btn.btn-primary:hover,
a.btn.btn-primary:focus-visible,
button.btn.btn-success:hover:not(:disabled),
button.btn.btn-success:focus-visible:not(:disabled),
a.btn.btn-success:hover,
a.btn.btn-success:focus-visible {
    color: #ffffff !important;
    background-color: var(--n-blue-dark) !important;
    background-image: linear-gradient(135deg, var(--n-blue-dark) 0%, var(--n-blue) 100%) !important;
    border-color: var(--n-blue-dark) !important;
    box-shadow: 0 18px 30px rgba(0, 107, 181, 0.2) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
    outline: none !important;
}

button.secondary-btn,
a.secondary-btn,
button.n-btn-secondary,
a.n-btn-secondary,
button.n-btn-link,
a.n-btn-link,
button.btn.btn-secondary,
a.btn.btn-secondary,
button.btn.btn-outline-secondary,
a.btn.btn-outline-secondary {
    min-height: var(--n-btn-height) !important;
    padding: 0 1rem !important;
    border: 1px solid var(--n-border-strong) !important;
    border-radius: var(--n-btn-radius) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--n-btn-gap) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    color: var(--n-text) !important;
    background: linear-gradient(180deg, #ffffff, #f7fbff) !important;
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.04) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease !important;
    -webkit-appearance: none;
    appearance: none;
}

button.secondary-btn:hover:not(:disabled),
button.secondary-btn:focus-visible:not(:disabled),
a.secondary-btn:hover,
a.secondary-btn:focus-visible,
button.n-btn-secondary:hover:not(:disabled),
button.n-btn-secondary:focus-visible:not(:disabled),
button.n-btn-link:hover:not(:disabled),
button.n-btn-link:focus-visible:not(:disabled),
a.n-btn-link:hover,
a.n-btn-link:focus-visible,
button.btn.btn-secondary:hover:not(:disabled),
button.btn.btn-secondary:focus-visible:not(:disabled),
a.btn.btn-secondary:hover,
a.btn.btn-secondary:focus-visible,
button.btn.btn-outline-secondary:hover:not(:disabled),
button.btn.btn-outline-secondary:focus-visible:not(:disabled),
a.btn.btn-outline-secondary:hover,
a.btn.btn-outline-secondary:focus-visible {
    color: var(--n-text) !important;
    background: #f4f8fc !important;
    border-color: rgba(0, 107, 181, 0.2) !important;
    box-shadow: 0 14px 24px rgba(15, 23, 42, 0.06) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
    outline: none !important;
}

button.secondary-btn.secondary-btn-accent,
a.secondary-btn.secondary-btn-accent,
button.modal-link-btn,
a.modal-link-btn,
button.btn.btn-outline-primary,
a.btn.btn-outline-primary {
    color: var(--n-blue) !important;
    border-color: rgba(0, 107, 181, 0.24) !important;
    background: rgba(0, 107, 181, 0.08) !important;
}

button.secondary-btn.secondary-btn-accent:hover:not(:disabled),
button.secondary-btn.secondary-btn-accent:focus-visible:not(:disabled),
a.secondary-btn.secondary-btn-accent:hover,
a.secondary-btn.secondary-btn-accent:focus-visible,
button.modal-link-btn:hover:not(:disabled),
button.modal-link-btn:focus-visible:not(:disabled),
a.modal-link-btn:hover,
a.modal-link-btn:focus-visible,
button.btn.btn-outline-primary:hover:not(:disabled),
button.btn.btn-outline-primary:focus-visible:not(:disabled),
a.btn.btn-outline-primary:hover,
a.btn.btn-outline-primary:focus-visible {
    color: var(--n-blue-dark) !important;
    background: rgba(0, 107, 181, 0.14) !important;
    border-color: rgba(0, 107, 181, 0.3) !important;
}

button.secondary-btn.secondary-btn-quiet,
a.secondary-btn.secondary-btn-quiet {
    box-shadow: none !important;
}

button.danger-btn,
a.danger-btn,
button.ghost-danger-btn,
a.ghost-danger-btn,
button.btn.btn-danger,
a.btn.btn-danger,
button.btn.btn-outline-danger,
a.btn.btn-outline-danger {
    min-height: var(--n-btn-height) !important;
    padding: 0 1rem !important;
    border: 0 !important;
    border-radius: var(--n-btn-radius) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--n-btn-gap) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #d64545, #ef4444) !important;
    box-shadow: 0 14px 24px rgba(220, 53, 69, 0.18) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease !important;
}

button.danger-btn:hover:not(:disabled),
button.danger-btn:focus-visible:not(:disabled),
a.danger-btn:hover,
a.danger-btn:focus-visible,
button.ghost-danger-btn:hover:not(:disabled),
button.ghost-danger-btn:focus-visible:not(:disabled),
a.ghost-danger-btn:hover,
a.ghost-danger-btn:focus-visible,
button.btn.btn-danger:hover:not(:disabled),
button.btn.btn-danger:focus-visible:not(:disabled),
a.btn.btn-danger:hover,
a.btn.btn-danger:focus-visible,
button.btn.btn-outline-danger:hover:not(:disabled),
button.btn.btn-outline-danger:focus-visible:not(:disabled),
a.btn.btn-outline-danger:hover,
a.btn.btn-outline-danger:focus-visible {
    color: #ffffff !important;
    background: linear-gradient(135deg, #b73535, #dc3545) !important;
    border-color: transparent !important;
    box-shadow: 0 18px 30px rgba(220, 53, 69, 0.22) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
    outline: none !important;
}

button.primary-btn:disabled,
button.config-primary-btn:disabled,
button.refresh-btn:disabled,
button.n-btn-primary:disabled,
input.n-btn-primary[type="button"]:disabled,
input.n-btn-primary[type="submit"]:disabled,
button.secondary-btn:disabled,
button.n-btn-secondary:disabled,
button.n-btn-link:disabled,
button.danger-btn:disabled,
button.ghost-danger-btn:disabled,
button.btn:disabled {
    opacity: 0.65 !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: none !important;
}

.action-group,
.config-action-group,
.n-action-group {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.35rem !important;
    padding: 0.25rem !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-radius: 0.8rem !important;
    background: #ffffff !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04) !important;
}

button.action-btn,
button.config-action-btn,
button.n-action-btn,
button.icon-btn {
    width: var(--n-action-size) !important;
    height: var(--n-action-size) !important;
    min-height: var(--n-action-size) !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: var(--n-action-radius) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #eef3f7 !important;
    color: #51687d !important;
    box-shadow: none !important;
    flex-shrink: 0 !important;
    transition: transform 0.15s ease, filter 0.15s ease !important;
}

button.action-btn:hover,
button.config-action-btn:hover,
button.n-action-btn:hover,
button.icon-btn:hover {
    transform: translateY(-1px) !important;
    filter: brightness(0.98) !important;
}

button.action-btn > i,
button.config-action-btn > i,
button.n-action-btn > i,
button.icon-btn > i {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    pointer-events: none !important;
}

button.action-btn > svg,
button.config-action-btn > svg,
button.n-action-btn > svg,
button.icon-btn > svg {
    width: 1rem !important;
    height: 1rem !important;
    pointer-events: none !important;
}

button.action-btn.action-view,
button.config-action-btn.action-view,
button.n-action-btn.n-action-view,
button.icon-btn.icon-btn-view,
.action-view,
.n-action-view,
.icon-btn-view {
    background: var(--n-action-view-bg) !important;
    color: var(--n-action-view-color) !important;
}

button.action-btn.action-edit,
button.config-action-btn.action-edit,
button.n-action-btn.n-action-edit,
button.icon-btn.action-edit,
.action-edit,
.n-action-edit {
    background: var(--n-action-edit-bg) !important;
    color: var(--n-action-edit-color) !important;
}

button.action-btn.action-delete,
button.config-action-btn.action-delete,
button.n-action-btn.n-action-delete,
button.icon-btn.icon-btn-danger,
.action-delete,
.n-action-delete,
.icon-btn-danger {
    background: var(--n-action-delete-bg) !important;
    color: var(--n-action-delete-color) !important;
}

.action-reset {
    background: rgba(13, 110, 253, 0.12) !important;
    color: #0d6efd !important;
}

.action-unlock {
    background: rgba(245, 158, 11, 0.16) !important;
    color: #9c6b00 !important;
}

button.view-btn,
a.view-btn {
    min-height: var(--n-btn-height-compact) !important;
    padding: 0 0.95rem !important;
    border: 1px solid rgba(0, 107, 181, 0.16) !important;
    border-radius: var(--n-btn-radius-compact) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    color: var(--n-blue) !important;
    background: linear-gradient(180deg, #f7fbff, #edf5ff) !important;
    box-shadow: 0 10px 18px rgba(0, 107, 181, 0.08) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease !important;
}

button.view-btn:hover,
button.view-btn:focus-visible,
a.view-btn:hover,
a.view-btn:focus-visible {
    color: var(--n-blue-dark) !important;
    background: #e9f4ff !important;
    border-color: rgba(0, 107, 181, 0.22) !important;
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.1) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
    outline: none !important;
}

/* Auth panels: aurora and light-trail background */
.main-viewport.auth-ps3-shell {
    position: relative;
    overflow: hidden;
}

.brand-side.auth-ps3-side {
    position: relative;
    isolation: isolate;
    background:
        radial-gradient(circle at 12% 18%, rgba(110, 236, 255, 0.2) 0%, transparent 26%),
        radial-gradient(circle at 82% 16%, rgba(120, 164, 255, 0.18) 0%, transparent 28%),
        radial-gradient(circle at 54% 82%, rgba(98, 255, 214, 0.14) 0%, transparent 32%),
        linear-gradient(160deg, #04102b 0%, #08204f 34%, #0a4486 70%, #0c72b6 100%);
    box-shadow: inset -56px 0 120px rgba(1, 11, 31, 0.22);
}

.brand-side.auth-ps3-side::before,
.brand-side.auth-ps3-side::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.brand-side.auth-ps3-side::before {
    width: 42rem;
    height: 24rem;
    top: -6rem;
    left: -12rem;
    border-radius: 58% 42% 62% 38% / 58% 40% 60% 42%;
    background: radial-gradient(circle at 45% 50%, rgba(162, 255, 233, 0.28) 0%, rgba(81, 193, 255, 0.18) 42%, transparent 76%);
    filter: blur(34px);
    animation: auth-aurora-cloud-a 20s ease-in-out infinite alternate;
}

.brand-side.auth-ps3-side::after {
    width: 46rem;
    height: 28rem;
    right: -16rem;
    bottom: -14rem;
    border-radius: 46% 54% 42% 58% / 56% 48% 52% 44%;
    background: radial-gradient(circle at 36% 48%, rgba(119, 158, 255, 0.24) 0%, rgba(66, 255, 221, 0.12) 40%, transparent 74%);
    filter: blur(38px);
    animation: auth-aurora-cloud-b 24s ease-in-out infinite alternate-reverse;
}

.brand-side.auth-ps3-side .glass-card {
    position: relative;
    z-index: 2;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.07) 100%);
    border: 1px solid rgba(216, 246, 255, 0.18);
    box-shadow: 0 34px 78px rgba(1, 10, 29, 0.28);
    backdrop-filter: blur(18px) saturate(120%);
}

.auth-ps3-scene {
    position: absolute;
    inset: -12%;
    pointer-events: none;
    z-index: 0;
    filter: saturate(118%);
}

.auth-ps3-orb,
.auth-ps3-trail,
.auth-ps3-spark {
    position: absolute;
    display: block;
}

.auth-ps3-orb {
    border-radius: 50%;
    mix-blend-mode: screen;
    filter: blur(24px);
}

.auth-ps3-orb-a {
    width: 24rem;
    height: 14rem;
    top: 4%;
    left: 2%;
    background: radial-gradient(circle at 42% 52%, rgba(174, 255, 236, 0.26) 0%, rgba(98, 196, 255, 0.14) 48%, transparent 78%);
    animation: auth-aurora-orb-a 18s ease-in-out infinite;
}

.auth-ps3-orb-b {
    width: 30rem;
    height: 18rem;
    right: -2%;
    top: 50%;
    background: radial-gradient(circle at 34% 48%, rgba(118, 165, 255, 0.24) 0%, rgba(59, 255, 218, 0.1) 50%, transparent 78%);
    animation: auth-aurora-orb-b 24s ease-in-out infinite;
}

.auth-ps3-trail {
    left: -28%;
    width: 156%;
    border-radius: 52% 48% 58% 42% / 62% 38% 62% 38%;
    mix-blend-mode: screen;
    transform-origin: center;
}

.auth-ps3-trail::before,
.auth-ps3-trail::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
}

.auth-ps3-trail::before {
    background: linear-gradient(90deg, transparent 8%, rgba(104, 250, 245, 0.08) 22%, rgba(141, 255, 220, 0.7) 42%, rgba(255, 255, 255, 0.82) 51%, rgba(114, 173, 255, 0.66) 61%, rgba(24, 59, 170, 0.12) 76%, transparent 92%);
    filter: blur(5px);
}

.auth-ps3-trail::after {
    inset: 10% 4%;
    background: linear-gradient(90deg, transparent 14%, rgba(255, 255, 255, 0.04) 28%, rgba(103, 255, 223, 0.28) 48%, rgba(160, 222, 255, 0.22) 64%, transparent 84%);
    filter: blur(28px);
}

.auth-ps3-trail-a {
    top: 6%;
    height: 14rem;
    animation: auth-aurora-ribbon-a 20s ease-in-out infinite;
}

.auth-ps3-trail-b {
    top: 30%;
    height: 16rem;
    opacity: 0.82;
    animation: auth-aurora-ribbon-b 24s ease-in-out infinite -8s;
}

.auth-ps3-trail-c {
    top: 60%;
    height: 12rem;
    opacity: 0.68;
    animation: auth-aurora-ribbon-c 18s ease-in-out infinite -14s;
}

.auth-ps3-spark {
    height: 0.24rem;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.96) 50%, transparent 100%);
    filter: blur(1px);
    opacity: 0;
    transform: rotate(-12deg);
}

.auth-ps3-spark-a {
    top: 24%;
    left: 62%;
    width: 7rem;
    animation: auth-aurora-spark 8s ease-out infinite 1s;
}

.auth-ps3-spark-b {
    top: 66%;
    left: 18%;
    width: 5rem;
    animation: auth-aurora-spark 9.5s ease-out infinite 4s;
}

.form-side.auth-ps3-form {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 8% 10%, rgba(147, 244, 255, 0.12) 0%, transparent 24%),
        linear-gradient(180deg, #ffffff 0%, #f3f9ff 58%, #eef7ff 100%);
}

.form-side.auth-ps3-form::before,
.form-side.auth-ps3-form::after {
    content: "";
    position: absolute;
    inset: auto;
    pointer-events: none;
    z-index: 0;
    mix-blend-mode: screen;
}

.form-side.auth-ps3-form::before {
    top: -10%;
    right: -18%;
    width: 32rem;
    height: 14rem;
    border-radius: 50%;
    background: radial-gradient(circle at 40% 50%, rgba(160, 255, 233, 0.18) 0%, rgba(102, 197, 255, 0.12) 46%, transparent 74%);
    filter: blur(30px);
}

.form-side.auth-ps3-form::after {
    left: -20%;
    bottom: -18%;
    width: 34rem;
    height: 12rem;
    border-radius: 50%;
    background: radial-gradient(circle at 55% 50%, rgba(117, 169, 255, 0.14) 0%, rgba(79, 255, 212, 0.1) 42%, transparent 74%);
    filter: blur(32px);
}

.form-side.auth-ps3-form .login-container-pro {
    position: relative;
    z-index: 1;
}

@keyframes auth-aurora-cloud-a {
    0% {
        transform: translate3d(0, 0, 0) rotate(-6deg) scale(0.96);
        opacity: 0.72;
    }

    50% {
        transform: translate3d(2rem, -1.5rem, 0) rotate(-2deg) scale(1.04);
        opacity: 0.9;
    }

    100% {
        transform: translate3d(4rem, 1rem, 0) rotate(2deg) scale(1.08);
        opacity: 0.82;
    }
}

@keyframes auth-aurora-cloud-b {
    0% {
        transform: translate3d(0, 0, 0) rotate(8deg) scale(0.94);
        opacity: 0.56;
    }

    50% {
        transform: translate3d(-3rem, 2rem, 0) rotate(3deg) scale(1.02);
        opacity: 0.72;
    }

    100% {
        transform: translate3d(-6rem, -1rem, 0) rotate(-2deg) scale(1.08);
        opacity: 0.64;
    }
}

@keyframes auth-aurora-orb-a {
    0% {
        transform: translate3d(0, 0, 0) scale(0.92);
        opacity: 0.42;
    }

    50% {
        transform: translate3d(3rem, -1rem, 0) scale(1.08);
        opacity: 0.74;
    }

    100% {
        transform: translate3d(6rem, 1rem, 0) scale(0.98);
        opacity: 0.48;
    }
}

@keyframes auth-aurora-orb-b {
    0% {
        transform: translate3d(0, 0, 0) scale(0.94);
        opacity: 0.28;
    }

    50% {
        transform: translate3d(-3rem, 2rem, 0) scale(1.06);
        opacity: 0.54;
    }

    100% {
        transform: translate3d(-5rem, -2rem, 0) scale(1);
        opacity: 0.36;
    }
}

@keyframes auth-aurora-ribbon-a {
    0% {
        transform: translate3d(-10%, 12%, 0) rotate(-12deg) scaleX(0.94) scaleY(0.9);
        opacity: 0;
    }

    18% {
        opacity: 0.7;
    }

    54% {
        transform: translate3d(3%, -2%, 0) rotate(-8deg) scaleX(1.02) scaleY(1.08);
        opacity: 0.9;
    }

    100% {
        transform: translate3d(18%, -18%, 0) rotate(-2deg) scaleX(1.12) scaleY(0.94);
        opacity: 0;
    }
}

@keyframes auth-aurora-ribbon-b {
    0% {
        transform: translate3d(-12%, 10%, 0) rotate(-10deg) scaleX(0.92) scaleY(0.94);
        opacity: 0;
    }

    22% {
        opacity: 0.54;
    }

    56% {
        transform: translate3d(4%, -4%, 0) rotate(-6deg) scaleX(1.04) scaleY(1.1);
        opacity: 0.84;
    }

    100% {
        transform: translate3d(16%, -20%, 0) rotate(-1deg) scaleX(1.14) scaleY(0.96);
        opacity: 0;
    }
}

@keyframes auth-aurora-ribbon-c {
    0% {
        transform: translate3d(-8%, 14%, 0) rotate(-9deg) scaleX(0.96) scaleY(0.9);
        opacity: 0;
    }

    20% {
        opacity: 0.42;
    }

    58% {
        transform: translate3d(6%, -1%, 0) rotate(-5deg) scaleX(1.06) scaleY(1.04);
        opacity: 0.68;
    }

    100% {
        transform: translate3d(20%, -14%, 0) rotate(0deg) scaleX(1.12) scaleY(0.92);
        opacity: 0;
    }
}

@keyframes auth-aurora-spark {
    0% {
        transform: translate3d(-2rem, 0.5rem, 0) rotate(-14deg) scaleX(0.45);
        opacity: 0;
    }

    24% {
        opacity: 0.92;
    }

    100% {
        transform: translate3d(8rem, -1.25rem, 0) rotate(-14deg) scaleX(1.2);
        opacity: 0;
    }
}

@media (max-width: 992px) {
    .form-side.auth-ps3-form {
        background:
            radial-gradient(circle at 14% 10%, rgba(171, 245, 255, 0.24) 0%, transparent 24%),
            radial-gradient(circle at 100% 24%, rgba(107, 180, 255, 0.2) 0%, transparent 28%),
            linear-gradient(160deg, #07163b 0%, #0a2e68 56%, #0b77ba 100%);
    }

    .form-side.auth-ps3-form::before,
    .form-side.auth-ps3-form::after {
        position: absolute;
        left: -28%;
        width: 156%;
        border-radius: 54% 46% 60% 40% / 62% 38% 62% 38%;
        mix-blend-mode: screen;
    }

    .form-side.auth-ps3-form::before {
        top: 10%;
        height: 10rem;
        background: linear-gradient(90deg, transparent 12%, rgba(110, 255, 223, 0.16) 28%, rgba(255, 255, 255, 0.66) 48%, rgba(128, 209, 255, 0.78) 58%, transparent 86%);
        filter: blur(18px);
        transform: rotate(-14deg);
        animation: auth-aurora-mobile-a 13s ease-in-out infinite;
    }

    .form-side.auth-ps3-form::after {
        bottom: 6%;
        height: 8rem;
        background: linear-gradient(90deg, transparent 20%, rgba(136, 255, 228, 0.14) 34%, rgba(255, 255, 255, 0.52) 52%, rgba(107, 180, 255, 0.72) 62%, transparent 86%);
        filter: blur(20px);
        transform: rotate(-8deg);
        animation: auth-aurora-mobile-b 15s ease-in-out infinite -6s;
        opacity: 0.82;
    }

    .form-side.auth-ps3-form .login-container-pro {
        box-shadow: 0 28px 64px rgba(4, 18, 48, 0.24);
        border: 1px solid rgba(255, 255, 255, 0.54);
    }
}

@keyframes auth-aurora-mobile-a {
    0% {
        transform: translate3d(-10%, 10%, 0) rotate(-14deg) scaleX(0.92) scaleY(0.92);
        opacity: 0;
    }

    24% {
        opacity: 0.9;
    }

    100% {
        transform: translate3d(18%, -14%, 0) rotate(-7deg) scaleX(1.08) scaleY(1.08);
        opacity: 0;
    }
}

@keyframes auth-aurora-mobile-b {
    0% {
        transform: translate3d(-8%, 8%, 0) rotate(-9deg) scaleX(0.94) scaleY(0.9);
        opacity: 0;
    }

    22% {
        opacity: 0.72;
    }

    100% {
        transform: translate3d(16%, -12%, 0) rotate(-3deg) scaleX(1.12) scaleY(1.04);
        opacity: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .brand-side.auth-ps3-side::before,
    .brand-side.auth-ps3-side::after,
    .auth-ps3-orb,
    .auth-ps3-trail,
    .auth-ps3-spark,
    .form-side.auth-ps3-form::before,
    .form-side.auth-ps3-form::after {
        animation: none !important;
    }
}

.numerica-swal-popup {
    width: min(32rem, calc(100vw - 2rem));
    padding: 1.45rem 1.45rem 1.3rem;
    border-radius: 28px;
    border: 1px solid rgba(0, 107, 181, 0.1);
    background:
        radial-gradient(circle at top right, rgba(56, 189, 248, 0.12), transparent 24%),
        radial-gradient(circle at top left, rgba(0, 107, 181, 0.08), transparent 30%),
        linear-gradient(180deg, #ffffff, #f7fbff);
    box-shadow: 0 30px 62px rgba(15, 23, 42, 0.18);
}

.numerica-swal-popup .swal2-icon {
    margin-top: 0.1rem;
    margin-bottom: 0.9rem;
    transform: scale(0.94);
}

.numerica-swal-close {
    color: #6a8197 !important;
    transition: transform 0.18s ease, color 0.18s ease;
}

.numerica-swal-close:hover {
    transform: translateY(-1px);
    color: #17324a !important;
}

.numerica-swal-title {
    color: #1f3650;
    font-size: 1.32rem;
    font-weight: 900;
    letter-spacing: 0;
}

.numerica-swal-body {
    color: #5f7388;
    font-size: 0.96rem;
    line-height: 1.55;
}

.numerica-swal-actions {
    width: 100%;
    gap: 0.75rem;
    margin-top: 1.35rem;
    justify-content: flex-end;
}

.numerica-swal-confirm,
.numerica-swal-cancel {
    min-height: 46px;
    margin: 0;
    padding: 0 1.05rem;
    border-radius: 16px;
    font-size: 0.94rem;
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.numerica-swal-confirm {
    border: 0;
    color: #ffffff;
}

.numerica-swal-confirm-primary {
    background: linear-gradient(135deg, #006bb5, #2793d4);
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.22);
}

.numerica-swal-confirm-danger {
    background: linear-gradient(135deg, #c23b4b, #dc3545);
    box-shadow: 0 14px 24px rgba(220, 53, 69, 0.2);
}

.numerica-swal-cancel {
    border: 1px solid #d7e3ee;
    background: #ffffff;
    color: #1f3650;
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.05);
}

.numerica-swal-confirm:hover,
.numerica-swal-cancel:hover {
    transform: translateY(-1px);
}

@media (max-width: 640px) {
    .numerica-swal-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .numerica-swal-confirm,
    .numerica-swal-cancel {
        width: 100%;
    }
}

/* ==========================================================
   DOCUMENTOS - CABECERA, HISTORIALES Y CONTROLES COMPARTIDOS
========================================================== */
.docs-form-hero {
    margin-bottom: 1rem;
    border-radius: 28px;
    border: 1px solid rgba(0, 107, 181, 0.12);
    background:
        radial-gradient(circle at top left, rgba(56, 189, 248, 0.2), transparent 34%),
        radial-gradient(circle at bottom right, rgba(14, 165, 233, 0.14), transparent 30%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(244, 249, 255, 0.96));
    box-shadow: 0 22px 44px rgba(15, 23, 42, 0.08);
    overflow: hidden;
}

.docs-form-hero-body {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1.3rem 1.4rem;
}

.docs-form-hero-copy {
    display: grid;
    gap: 0.55rem;
}

.docs-form-kicker,
.docs-history-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--n-blue);
}

.docs-form-title {
    margin: 0;
    color: #17324a;
    font-size: 1.5rem;
    font-weight: 900;
    letter-spacing: 0;
}

.docs-form-text {
    margin: 0;
    max-width: 70ch;
    color: #57728d;
    font-size: 0.95rem;
    line-height: 1.7;
}

.docs-form-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
    margin-top: 0.35rem;
}

.docs-form-metric {
    padding: 0.9rem 1rem;
    border-radius: 18px;
    border: 1px solid rgba(0, 107, 181, 0.12);
    background: rgba(255, 255, 255, 0.78);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.docs-form-metric span {
    display: block;
    margin-bottom: 0.32rem;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #69819a;
}

.docs-form-metric strong {
    display: block;
    color: #17324a;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.25;
    word-break: break-word;
}

.docs-form-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.8rem;
}

.docs-form-toolbar .n-btn,
.docs-form-toolbar .n-btn-link,
.docs-form-toolbar .n-btn-primary,
.docs-form-toolbar .n-btn-secondary {
    min-height: 48px;
    padding-inline: 1rem;
    border-radius: 16px;
    white-space: nowrap;
}

.docs-history-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1200;
    background: rgba(9, 25, 45, 0.58);
    backdrop-filter: blur(6px);
}

.docs-history-shell {
    position: fixed;
    inset: 0;
    z-index: 1210;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem;
}

.docs-history-dialog {
    width: min(1420px, calc(100vw - 2.4rem));
    max-height: calc(100vh - 2.4rem);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(0, 107, 181, 0.12);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.98));
    box-shadow: 0 36px 70px rgba(15, 23, 42, 0.26);
}

.docs-history-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.2rem 1.3rem;
    border-bottom: 1px solid #e2ecf4;
    background:
        radial-gradient(circle at top left, rgba(0, 107, 181, 0.09), transparent 34%),
        linear-gradient(180deg, #ffffff, #f8fbff);
}

.docs-history-copy {
    display: grid;
    gap: 0.45rem;
}

.docs-history-copy h3 {
    margin: 0;
    color: #17324a;
    font-size: 1.3rem;
    font-weight: 900;
    letter-spacing: 0;
}

.docs-history-copy p {
    margin: 0;
    color: #5c7691;
    font-size: 0.92rem;
    line-height: 1.6;
}

.docs-history-close {
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #edf4fa;
    color: #49647e;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.docs-history-close:hover {
    transform: translateY(-1px);
    background: #e4eef7;
    color: #17324a;
}

.docs-history-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 1.1rem 1.2rem 1.3rem;
    background: linear-gradient(180deg, #eef4fb 0%, #e8f1fa 100%);
}

.docs-history-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.2rem 1.2rem;
    border-top: 1px solid #deebf5;
    background: rgba(255, 255, 255, 0.98);
}

.docs-history-frame > *:last-child {
    margin-bottom: 0;
}

.docs-total-card {
    padding: 1.2rem 1.25rem;
    border-radius: 22px;
    border: 1px solid #d9e8f4;
    background:
        radial-gradient(circle at top right, rgba(0, 107, 181, 0.09), transparent 30%),
        linear-gradient(180deg, #ffffff, #f8fbff);
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.06);
}

.docs-total-card-header {
    margin-bottom: 0.95rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid #e3edf6;
}

.docs-total-card-header span {
    display: inline-flex;
    align-items: center;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--n-blue);
}

.docs-total-card-header h6 {
    margin: 0.4rem 0 0;
    color: #17324a;
    font-size: 1.1rem;
    font-weight: 900;
}

.docs-total-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    margin-bottom: 0.75rem;
    color: #5b748c;
    font-size: 0.94rem;
}

.docs-total-row strong {
    color: #17324a;
}

.docs-total-row--danger {
    color: #c23b4b;
    font-weight: 800;
}

.docs-total-row--accent {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #e3edf6;
}

.docs-total-row--accent strong {
    font-size: 2rem;
    color: var(--n-blue);
    letter-spacing: 0;
}

.docs-total-inline-input {
    width: 110px;
    position: relative;
}

.docs-total-inline-input input {
    padding-right: 1.7rem !important;
}

.docs-total-inline-input span {
    position: absolute;
    top: 50%;
    right: 0.7rem;
    transform: translateY(-50%);
    color: #c23b4b;
    font-weight: 800;
}

.docs-code-modal-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-bottom: 1rem;
}

.docs-code-tab {
    min-height: 42px;
    padding: 0 1rem;
    border-radius: 14px;
    border: 1px solid #d7e5f1;
    background: #ffffff;
    color: #4a6480;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    font-weight: 800;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.docs-code-tab:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 107, 181, 0.22);
}

.docs-code-tab.is-active {
    border-color: transparent;
    background: linear-gradient(135deg, rgba(0, 107, 181, 0.12), rgba(255, 255, 255, 0.98));
    color: var(--n-blue);
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.12);
}

.docs-code-summary {
    margin-bottom: 1rem;
    color: #5a748e;
    font-size: 0.88rem;
    line-height: 1.6;
}

.docs-code-table {
    border: 1px solid #e2ecf4;
    border-radius: 20px;
    overflow: hidden;
    background: #ffffff;
}

.docs-code-table .table {
    margin-bottom: 0;
}

.docs-code-table thead th {
    background: linear-gradient(180deg, #f7fbff, #eef5fb);
    color: #31526d;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-bottom: 1px solid #dfeaf4;
    padding: 1rem 1.05rem;
}

.docs-code-table tbody td {
    padding: 0.95rem 1.05rem;
    border-bottom: 1px solid #eef3f7;
    vertical-align: middle;
}

.docs-code-table tbody tr:hover td {
    background: rgba(0, 107, 181, 0.035);
}

.docs-code-use-btn {
    min-height: 38px;
    padding: 0 0.9rem;
    border: 0;
    border-radius: 12px;
    background: rgba(0, 107, 181, 0.1);
    color: var(--n-blue);
    font-weight: 800;
}

.docs-code-type-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 0.7rem;
    border-radius: 999px;
    background: rgba(0, 107, 181, 0.1);
    color: var(--n-blue);
    font-size: 0.76rem;
    font-weight: 800;
}

.toolbar-actions,
.toolbar-actions-expanded {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.toolbar-actions-expanded {
    align-items: stretch;
}

.search-box {
    min-width: min(100%, 420px);
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.2rem 0.2rem 0.2rem 0.85rem;
    border-radius: 18px;
    border: 1px solid #dbe7f1;
    background: #ffffff;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.03);
}

.search-box:focus-within {
    border-color: var(--n-blue);
    box-shadow: 0 0 0 4px rgba(0, 107, 181, 0.12);
}

.search-icon {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 107, 181, 0.1);
    color: var(--n-blue);
    flex-shrink: 0;
}

.search-input {
    flex: 1;
    min-width: 0;
    border: 0;
    background: transparent;
    color: var(--n-dark);
    font-size: 0.95rem;
    outline: none;
}

.search-input::placeholder {
    color: #8da1b6;
}

.search-clear,
.refresh-btn,
.report-btn,
.filter-reset-btn {
    border: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

.search-clear {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    background: #eef3f8;
    color: #5b7086;
}

.refresh-btn,
.report-btn,
.filter-reset-btn {
    min-height: 48px;
    padding: 0 1rem;
    border-radius: 16px;
}

.refresh-btn {
    background: linear-gradient(135deg, var(--n-blue), #2793d4);
    color: #ffffff;
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.18);
}

.report-btn {
    background: linear-gradient(135deg, #16324a, #24547c);
    color: #ffffff;
    box-shadow: 0 14px 24px rgba(22, 50, 74, 0.18);
}

.filter-reset-btn {
    background: #eef4f9;
    color: #4f657b;
    border: 1px solid #d8e5f0;
}

.search-clear:hover,
.refresh-btn:hover,
.report-btn:hover,
.filter-reset-btn:hover,
.row-action-btn:hover,
.docs-code-use-btn:hover {
    transform: translateY(-1px);
}

.date-filter-group {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.date-filter-box {
    min-width: 148px;
    display: grid;
    gap: 0.35rem;
    padding: 0.65rem 0.8rem;
    border-radius: 18px;
    border: 1px solid #dbe7f1;
    background: #ffffff;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.03);
}

.date-filter-box span {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #648098;
}

.date-filter-input {
    min-height: 40px;
    border: 1px solid #dbe7f1;
    border-radius: 12px;
    padding: 0 0.8rem;
    background: linear-gradient(180deg, #ffffff, #f7fbff);
    color: var(--n-dark);
    font-weight: 700;
    outline: none;
}

.date-filter-input:focus {
    border-color: var(--n-blue);
    box-shadow: 0 0 0 4px rgba(0, 107, 181, 0.12);
}

.table-badge {
    min-height: 34px;
    padding: 0 0.9rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 107, 181, 0.1);
    color: var(--n-blue);
    font-size: 0.8rem;
    font-weight: 700;
}

.invoice-date {
    display: inline-flex;
    font-weight: 700;
    color: #34546f;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0 0.85rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.status-pill-success {
    background: rgba(25, 135, 84, 0.14);
    color: #198754;
}

.status-pill-info {
    background: rgba(13, 110, 253, 0.12);
    color: #0d6efd;
}

.status-pill-danger {
    background: rgba(220, 53, 69, 0.12);
    color: #c2384b;
}

.status-pill-muted {
    background: #eef3f8;
    color: #5b7086;
}

.row-actions.row-actions-main {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.55rem;
}

.row-action-btn {
    width: 116px;
    min-height: 44px;
    padding: 0 0.85rem;
    border: 0;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    font-weight: 800;
    font-size: 0.9rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.row-action-btn i {
    font-size: 0.95rem;
}

.row-action-view {
    background: #e6efff;
    color: #1f73f1;
}

.row-action-xml {
    background: #e4f4eb;
    color: #1c8e59;
}

.row-action-pdf {
    background: #fbe8ea;
    color: #cb4356;
}

.table-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.2rem 1.2rem;
}

.footer-metrics {
    display: flex;
    align-items: stretch;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.footer-metric {
    min-width: 170px;
    padding: 0.85rem 1rem;
    border-radius: 18px;
    border: 1px solid #e4edf5;
    background: #f9fbfe;
}

.footer-metric-highlight {
    background: linear-gradient(135deg, rgba(0, 107, 181, 0.1), rgba(255, 255, 255, 0.98));
    border-color: rgba(0, 107, 181, 0.14);
}

.footer-label {
    display: block;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #648098;
    margin-bottom: 0.35rem;
}

.footer-metric strong {
    color: var(--n-dark);
    font-size: 1.05rem;
    letter-spacing: 0;
}

.pagination-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pagination-btn {
    min-width: 42px;
    min-height: 42px;
    padding: 0 0.85rem;
    border-radius: 14px;
    border: 1px solid #d8e5f0;
    background: #ffffff;
    color: #3f5c77;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.pagination-btn:hover:not(:disabled) {
    transform: translateY(-1px);
    border-color: rgba(0, 107, 181, 0.28);
    box-shadow: 0 12px 22px rgba(0, 107, 181, 0.1);
}

.pagination-btn.is-active {
    border-color: transparent;
    background: linear-gradient(135deg, var(--n-blue), #2793d4);
    color: #ffffff;
    box-shadow: 0 14px 24px rgba(0, 107, 181, 0.18);
}

.pagination-btn-direction {
    padding: 0 1rem;
}

.pagination-btn:disabled {
    opacity: 0.55;
    cursor: not-allowed;
    box-shadow: none;
}

@media (max-width: 1199.98px) {
    .docs-form-hero-body {
        grid-template-columns: 1fr;
    }

    .docs-form-toolbar {
        justify-content: flex-start;
    }

    .docs-form-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .docs-history-shell {
        padding: 0.85rem;
    }

    .docs-history-dialog {
        width: min(100%, calc(100vw - 1.7rem));
        max-height: calc(100vh - 1.7rem);
    }

    .table-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .pagination-nav {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .docs-form-hero-body,
    .docs-history-header,
    .docs-form-toolbar {
        gap: 0.8rem;
    }

    .docs-form-metrics {
        grid-template-columns: 1fr;
    }

    .docs-history-copy h3 {
        font-size: 1.15rem;
    }

    .docs-history-body {
        padding: 0.9rem;
    }

    .docs-history-footer {
        padding: 0.9rem;
        justify-content: stretch;
    }

    .docs-history-footer .secondary-btn {
        width: 100%;
    }

    .search-box,
    .date-filter-box,
    .page-size-box,
    .table-badge,
    .footer-metric {
        width: 100%;
    }

    .row-actions.row-actions-main {
        align-items: stretch;
    }

    .row-action-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Unified emission document workspace */
.docs-unified-page {
    max-width: 1720px;
    margin: 0 auto;
    min-height: 100vh;
    color: #17324a;
    background-color: #eef4fb !important;
    background-image: radial-gradient(circle, rgba(120, 170, 214, 0.34) 1px, transparent 1px) !important;
    background-size: 28px 28px !important;
}

.docs-unified-page .n-card,
.docs-unified-page .docs-form-hero,
.docs-unified-page .guia-hero-card {
    margin-bottom: 12px !important;
    border-radius: 16px !important;
    border: 1px solid #d7e5f3 !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08) !important;
    overflow: hidden;
}

.docs-unified-page .docs-form-hero,
.docs-unified-page .guia-hero-card {
    border: 0 !important;
    background: linear-gradient(135deg, #ffffff 0%, #f4f9ff 58%, #eaf6ff 100%) !important;
}

.docs-unified-page .docs-form-hero-body,
.docs-unified-page .guia-hero-body {
    display: grid !important;
    grid-template-columns: minmax(0, 1.7fr) auto !important;
    gap: 14px !important;
    align-items: center !important;
    padding: 14px 16px !important;
}

.docs-unified-page .docs-form-kicker,
.docs-unified-page .guia-hero-kicker {
    display: inline-flex !important;
    align-items: center !important;
    margin-bottom: 6px !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.78) !important;
    color: #52708d !important;
    font-size: 0.72rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .docs-form-title,
.docs-unified-page .guia-hero-title {
    margin: 0 !important;
    color: #17324a !important;
    font-size: 1.35rem !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .docs-form-text,
.docs-unified-page .guia-hero-text {
    margin: 6px 0 0 !important;
    color: #5c7490 !important;
    font-size: 0.92rem !important;
    line-height: 1.45 !important;
    max-width: 64ch !important;
}

.docs-unified-page .docs-form-toolbar,
.docs-unified-page .guia-toolbar {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 10px !important;
}

.docs-unified-page .n-card-header,
.docs-unified-page .n-header-dark {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    min-height: 50px !important;
    padding: 12px 16px !important;
    border-bottom: 2px solid rgba(255, 255, 255, 0.15) !important;
    background: linear-gradient(135deg, #006bb5 0%, #0284c7 60%, #005691 100%) !important;
    color: #ffffff !important;
}

.docs-unified-page .n-card-header h5,
.docs-unified-page .n-header-dark h5,
.docs-unified-page .n-card-header h5.mb-0 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: 0.96rem !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15) !important;
}

.docs-unified-page .n-card-header small,
.docs-unified-page .n-header-dark small {
    display: inline-flex;
    align-items: center !important;
    padding: 3px 9px !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    border-radius: 20px !important;
    background: rgba(255, 255, 255, 0.18) !important;
    color: rgba(255, 255, 255, 0.9) !important;
    font-size: 0.71rem !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    backdrop-filter: blur(6px);
    margin-left: auto !important;
}

.docs-unified-page .n-card-body,
.docs-unified-page .compact-card-body {
    padding: 14px 16px !important;
    background: linear-gradient(180deg, #f5faff 0%, #eef4fb 100%) !important;
}

.docs-unified-page .n-label,
.docs-unified-page .ret-label {
    display: block !important;
    margin: 0 0 6px !important;
    color: #4f6a84 !important;
    font-size: 0.74rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .manual-field > .n-label {
    min-height: 2.2rem;
    display: flex !important;
    align-items: flex-end !important;
    line-height: 1.15 !important;
}

.docs-unified-page .n-input,
.docs-unified-page .n-select,
.docs-unified-page .n-textarea,
.docs-unified-page .ret-input {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    min-height: 40px !important;
    padding: 9px 11px !important;
    border: 2px solid #8dc0e7 !important;
    border-radius: 10px !important;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%) !important;
    color: #17324a !important;
    font-size: 0.9rem !important;
    box-shadow: inset 0 1px 2px rgba(11, 115, 196, 0.08), 0 6px 16px rgba(11, 115, 196, 0.08) !important;
    outline: none !important;
}

.docs-unified-page .n-input,
.docs-unified-page .n-select,
.docs-unified-page .ret-input {
    height: 40px !important;
}

.docs-unified-page .n-input:hover,
.docs-unified-page .n-input:focus,
.docs-unified-page .n-select:hover,
.docs-unified-page .n-select:focus,
.docs-unified-page .ret-input:hover,
.docs-unified-page .ret-input:focus {
    border-color: #0b73c4 !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(11, 115, 196, 0.14), 0 10px 22px rgba(11, 115, 196, 0.12) !important;
}

.docs-unified-page .n-input[readonly],
.docs-unified-page .n-input:disabled,
.docs-unified-page .n-select:disabled,
.docs-unified-page .ret-input[readonly],
.docs-unified-page .ret-input:disabled {
    background: linear-gradient(180deg, #eef7ff 0%, #e4f0fb 100%) !important;
    color: #355c7d !important;
    border-color: #94bddc !important;
    box-shadow: none !important;
}

.docs-unified-page .n-input-wrapper {
    position: relative !important;
}

.docs-unified-page .n-input-icon {
    position: absolute !important;
    top: 50% !important;
    left: 14px !important;
    transform: translateY(-50%) !important;
    color: #7b92aa !important;
    font-size: 1.05rem !important;
    pointer-events: none !important;
}

.docs-unified-page .n-input-with-icon {
    padding-left: 38px !important;
}

.docs-unified-page .manual-entry-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: 10px 12px !important;
    align-items: start !important;
}

.docs-unified-page .manual-field {
    min-width: 0 !important;
    display: grid !important;
    gap: 6px !important;
}

.docs-unified-page .manual-span-2 { grid-column: span 2 !important; }
.docs-unified-page .manual-span-3 { grid-column: span 3 !important; }
.docs-unified-page .manual-span-4 { grid-column: span 4 !important; }
.docs-unified-page .manual-span-5 { grid-column: span 5 !important; }
.docs-unified-page .manual-span-6 { grid-column: span 6 !important; }
.docs-unified-page .manual-span-8 { grid-column: span 8 !important; }
.docs-unified-page .manual-span-9 { grid-column: span 9 !important; }
.docs-unified-page .manual-span-12 { grid-column: span 12 !important; }

.docs-unified-page .guia-doc-overview,
.docs-unified-page .liquidacion-doc-overview {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 14px !important;
}

.docs-unified-page .guia-doc-pill,
.docs-unified-page .liquidacion-doc-pill {
    display: grid !important;
    gap: 2px !important;
    min-height: 74px !important;
    padding: 10px 12px !important;
    align-content: center !important;
    border: 1px solid #d9e8f5 !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, #fbfdff 0%, #f2f8ff 100%) !important;
}

.docs-unified-page .guia-doc-pill span,
.docs-unified-page .liquidacion-doc-pill span {
    color: #6b849d !important;
    font-size: 0.72rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .guia-doc-pill strong,
.docs-unified-page .liquidacion-doc-pill strong {
    color: #17324a !important;
    font-size: 0.95rem !important;
    font-weight: 900 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.docs-unified-page .guia-form-panels,
.docs-unified-page .liquidacion-form-panels {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.docs-unified-page .guia-form-panel,
.docs-unified-page .liquidacion-form-panel,
.docs-unified-page .n-section,
.docs-unified-page .n-section-alt {
    min-width: 0 !important;
    padding: 14px !important;
    border: 1px solid #dbe8f4 !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, #ffffff 0%, #f9fcff 100%) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

.docs-unified-page .guia-panel-title,
.docs-unified-page .liquidacion-panel-title {
    display: grid !important;
    gap: 4px !important;
    margin-bottom: 12px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid #e7eff8 !important;
}

.docs-unified-page .guia-panel-title span,
.docs-unified-page .liquidacion-panel-title span {
    color: #5d7a96 !important;
    font-size: 0.74rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .guia-panel-title strong,
.docs-unified-page .liquidacion-panel-title strong {
    color: #17324a !important;
    font-size: 1rem !important;
    font-weight: 900 !important;
}

.docs-unified-page .n-table-container,
.docs-unified-page .table-responsive {
    border: 1px solid #d7e5f3 !important;
    border-radius: 14px !important;
    background: #fbfdff !important;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.06) !important;
    overflow: auto !important;
}

.docs-unified-page .docs-total-card,
.docs-unified-page .purchase-summary-card,
.docs-unified-page [data-tour="invoice.totals-section"] {
    width: 100% !important;
    padding: 22px 24px !important;
    border: 1px solid #d7e5f3 !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08) !important;
}

.docs-unified-page .docs-total-card-header,
.docs-unified-page .purchase-summary-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 12px !important;
    align-items: center !important;
    margin-bottom: 14px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #e2edf7 !important;
}

.docs-unified-page .docs-total-card-header span,
.docs-unified-page .purchase-summary-kicker {
    color: #006bb5 !important;
    font-size: 0.72rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .docs-total-card-header h6,
.docs-unified-page .purchase-summary-heading {
    margin: 0 !important;
    color: #17324a !important;
    font-size: 1.05rem !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

.docs-unified-page .docs-total-row,
.docs-unified-page .purchase-summary-row,
.docs-unified-page [data-tour="invoice.totals-section"] > .d-flex {
    min-height: 34px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 7px 0 !important;
    border-bottom: 1px solid #edf3f9 !important;
    color: #3f556b !important;
    font-size: 0.93rem !important;
}

.docs-unified-page .docs-total-row span,
.docs-unified-page .purchase-summary-row span,
.docs-unified-page .purchase-summary-label {
    letter-spacing: 0 !important;
}

.docs-unified-page .docs-total-row strong,
.docs-unified-page .purchase-summary-value,
.docs-unified-page [data-tour="invoice.totals-section"] .fw-bold,
.docs-unified-page [data-tour="invoice.totals-section"] .fw-bolder {
    color: #17324a !important;
    font-weight: 900 !important;
}

.docs-unified-page .docs-total-row--danger,
.docs-unified-page [data-tour="invoice.totals-section"] .text-danger {
    color: #cf3c4f !important;
}

.docs-unified-page .docs-total-row--danger strong,
.docs-unified-page [data-tour="invoice.totals-section"] .text-danger.fw-bold {
    color: #cf3c4f !important;
}

.docs-unified-page .docs-total-row--accent,
.docs-unified-page .purchase-summary-row-accent,
.docs-unified-page [data-tour="invoice.totals-section"] > .d-flex:last-child {
    margin-top: 12px !important;
    padding-top: 16px !important;
    border-top: 1px solid #dce7f2 !important;
    border-bottom: 0 !important;
}

.docs-unified-page .docs-total-row--accent span,
.docs-unified-page .docs-total-row--accent strong,
.docs-unified-page .purchase-summary-row-accent .purchase-summary-label,
.docs-unified-page .purchase-summary-row-accent .purchase-summary-value,
.docs-unified-page [data-tour="invoice.totals-section"] > .d-flex:last-child span:last-child {
    color: #006bb5 !important;
    font-size: 1.45rem !important;
    font-weight: 900 !important;
}

.docs-unified-page .docs-total-row--accent span:first-child,
.docs-unified-page [data-tour="invoice.totals-section"] > .d-flex:last-child span:first-child {
    color: #17324a !important;
    font-size: 1.05rem !important;
}

.docs-unified-page .docs-total-inline-input,
.docs-unified-page .purchase-summary-total-inline {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 6px !important;
}

.docs-unified-page .purchase-summary-structured {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin-top: 8px !important;
}

.docs-unified-page .purchase-summary-cluster {
    min-width: 0 !important;
    padding: 12px !important;
    border: 1px solid #dbe8f4 !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, #fbfdff 0%, #f2f8ff 100%) !important;
}

.docs-unified-page .purchase-summary-cluster-title {
    margin-bottom: 8px !important;
    color: #006bb5 !important;
    font-size: 0.72rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
}

@media (max-width: 1199.98px) {
    .docs-unified-page .docs-form-hero-body,
    .docs-unified-page .guia-hero-body {
        grid-template-columns: 1fr !important;
    }

    .docs-unified-page .docs-form-toolbar,
    .docs-unified-page .guia-toolbar {
        justify-content: flex-start !important;
    }

    .docs-unified-page .purchase-summary-structured,
    .docs-unified-page .guia-form-panels,
    .docs-unified-page .liquidacion-form-panels {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 767.98px) {
    .docs-unified-page .guia-doc-overview,
    .docs-unified-page .liquidacion-doc-overview,
    .docs-unified-page .manual-entry-grid {
        grid-template-columns: 1fr !important;
    }

    .docs-unified-page [class*="manual-span-"] {
        grid-column: 1 / -1 !important;
    }

    .docs-unified-page .docs-total-card-header,
    .docs-unified-page .purchase-summary-header {
        grid-template-columns: 1fr !important;
    }
}
/* ── E-Declara: iconos y links blancos sobre fondo morado ── */
.edeclara-theme .menu-link,
.edeclara-theme .menu-button {
    color: rgba(255, 255, 255, 0.86);
}

.edeclara-theme .menu-icon {
    background: rgba(255, 255, 255, 0.10);
    color: rgba(255, 255, 255, 0.92);
}

.edeclara-theme .menu-link.active {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08));
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: inset 3px 0 0 #fff, 0 6px 14px rgba(30, 21, 84, 0.18);
    color: #ffffff;
}

.edeclara-theme .menu-link:hover,
.edeclara-theme .menu-button:hover {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff;
}

.edeclara-theme .submenu-panel {
    border-left-color: rgba(255, 255, 255, 0.18);
}
/* ── E-Declara: reset de strong en cards ── */
.edeclara-theme .spotlight-card strong,
.edeclara-theme .summary-real-item strong {
    min-height: unset !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: none !important;
    background-image: none !important;
    box-shadow: none !important;
    display: block !important;
    color: #6C63FF !important;
    font-size: 1.8rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    justify-content: unset !important;
    align-items: unset !important;
    white-space: normal !important;
    text-decoration: none !important;
}
.edeclara-theme .sidebar {
    background: radial-gradient(circle at top, rgba(255, 255, 255, 0.12), transparent 34%), linear-gradient(180deg, #2d1f7a 0%, #4a3db5 52%, #1e1554 100%);
}