:root {
    --bg: #eef5f7;
    --surface: #ffffff;
    --ink: #052f3d;
    --muted: #536979;
    --line: #c9d7de;
    --accent: #063848;
    --accent-strong: #022c3a;
    --nav: #022d39;
    --nav-soft: #36475a;
    --danger: #34445a;
    --success: #267a46;
    --logo-ring: #34445a;
    --soft-blue: #edf6f8;
    --soft-red: #eef1f5;
    --soft-green: #eaf7f1;
    --soft-amber: #fff5dc;
    --erp-body-bg: #eef5f7;
    --erp-navbar-bg: #022d39;
    --erp-navbar-bg-alt: #34445a;
    --erp-accent: #34445a;
    --erp-accent-soft: #eef1f5;
    --erp-card-bg: #ffffff;
    --erp-text: #052f3d;
    --erp-muted: #536979;
    --erp-border: rgba(6, 56, 72, 0.12);
    --bs-primary: #022d39;
    --bs-primary-rgb: 2, 45, 57;
    --bs-body-color: #052f3d;
    --bs-body-bg: #eef5f7;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    background: var(--bg);
    color: var(--ink);
    font-family: Arial, Helvetica, sans-serif;
}

.dashboard-page {
    min-height: 100vh;
    background: var(--erp-body-bg);
    color: var(--erp-text);
    font-family: "Segoe UI", Arial, sans-serif;
}

.auth-page {
    display: grid;
    place-items: center;
    padding: 24px;
    background:
        linear-gradient(135deg, rgba(2, 45, 57, 0.96), rgba(52, 68, 90, 0.9)),
        #022d39;
}

.auth-shell {
    width: min(100%, 440px);
}

.login-shell {
    width: min(100%, 1060px);
}

.auth-shell-wide {
    width: min(100%, 720px);
}

.public-page {
    min-height: 100vh;
    background: #022d39;
    color: #fff;
}

.public-shell {
    min-height: 100vh;
    width: 100%;
}

.public-home {
    min-height: 100vh;
    padding: 18px;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.11), transparent 24%),
        linear-gradient(135deg, #022d39 0%, #063848 52%, #34445a 100%);
}

.public-nav {
    align-items: center;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1160px;
    min-height: 54px;
}

.public-brand {
    align-items: center;
    color: #fff;
    display: inline-flex;
    font-weight: 800;
    gap: 12px;
    text-decoration: none;
}

.public-brand img {
    background: #fff;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 8px;
    height: 44px;
    object-fit: contain;
    padding: 4px;
    width: 44px;
}

.public-nav-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.public-link,
.public-login-link,
.primary-action,
.secondary-action {
    align-items: center;
    border-radius: 6px;
    display: inline-flex;
    font-weight: 800;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    text-decoration: none;
}

.public-link {
    color: rgba(255, 255, 255, 0.84);
}

.public-link:hover {
    color: #fff;
}

.public-login-link,
.primary-action {
    background: #fff;
    color: #022d39;
}

.public-login-link:hover,
.primary-action:hover {
    background: #eef5f7;
    color: #022d39;
}

.secondary-action {
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: #fff;
}

.primary-action,
.secondary-action {
    gap: 8px;
}

.secondary-action:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.public-hero-grid {
    align-items: center;
    display: grid;
    gap: 36px;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    margin: 0 auto;
    max-width: 1160px;
    min-height: calc(100vh - 116px);
    padding: 56px 0 34px;
}

.public-hero-copy {
    max-width: 640px;
    min-width: 0;
}

.public-kicker {
    color: rgba(255, 255, 255, 0.72);
    font-size: 13px;
    font-weight: 800;
    margin: 0 0 12px;
    text-transform: uppercase;
}

.public-hero-copy h1 {
    color: #fff;
    font-size: clamp(40px, 6vw, 68px);
    font-weight: 800;
    line-height: 1.05;
    margin: 0 0 18px;
    max-width: 760px;
}

.public-copy {
    color: rgba(255, 255, 255, 0.82);
    font-size: 18px;
    line-height: 1.6;
    margin: 0 0 28px;
    max-width: 660px;
}

.public-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-start;
}

.public-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.public-proof span {
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.76);
    padding: 12px 14px;
}

.public-proof strong {
    color: #fff;
    display: block;
    font-size: 20px;
}

.public-showcase {
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.48);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.24);
    color: var(--ink);
    padding: 28px;
}

.public-showcase-logo {
    display: block;
    height: 128px;
    margin: 0 0 22px;
    object-fit: contain;
    width: 128px;
}

.public-showcase-label {
    color: var(--accent);
    font-size: 13px;
    font-weight: 800;
    margin: 0 0 8px;
    text-transform: uppercase;
}

.public-showcase h2 {
    font-size: 26px;
    line-height: 1.18;
    margin: 0;
}

.public-showcase-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 24px;
}

.public-showcase-grid span {
    align-items: center;
    background: var(--soft-blue);
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--ink);
    display: flex;
    font-weight: 800;
    gap: 8px;
    min-height: 52px;
    padding: 10px;
}

.public-services,
.public-client-cta,
.public-footer {
    margin: 0 auto;
    max-width: 1160px;
}

.public-services {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 12px 0 34px;
}

.public-services article {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.38);
    border-radius: 8px;
    color: var(--ink);
    padding: 22px;
}

.public-services i {
    align-items: center;
    background: var(--accent);
    border-radius: 8px;
    color: #fff;
    display: inline-flex;
    font-size: 22px;
    height: 44px;
    justify-content: center;
    margin-bottom: 16px;
    width: 44px;
}

.public-services h2 {
    font-size: 20px;
    margin: 0 0 8px;
}

.public-services p {
    color: var(--muted);
    line-height: 1.55;
    margin: 0;
}

.public-client-cta {
    align-items: center;
    background: #fff;
    border-radius: 8px;
    color: var(--ink);
    display: flex;
    gap: 24px;
    justify-content: space-between;
    padding: 26px;
}

.public-client-cta .public-kicker {
    color: var(--accent);
}

.public-client-cta h2 {
    font-size: 28px;
    margin: 0 0 8px;
}

.public-client-cta p:last-child {
    color: var(--muted);
    line-height: 1.55;
    margin: 0;
    max-width: 620px;
}

.secondary-dark {
    border-color: var(--line);
    color: var(--ink);
}

.secondary-dark:hover {
    background: var(--soft-blue);
    color: var(--ink);
}

.public-footer {
    align-items: center;
    color: rgba(255, 255, 255, 0.76);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 26px 0 8px;
}

.public-footer div:first-child {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.public-footer a {
    color: #fff;
    text-decoration: none;
}

.public-socials {
    display: flex;
    gap: 10px;
}

.public-socials a {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 8px;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.login-panel {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 32px;
    box-shadow: 0 24px 70px rgba(29, 39, 32, 0.08);
}

.auth-card {
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(201, 215, 222, 0.9);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(2, 45, 57, 0.22);
    padding: 32px;
}

.login-experience {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
    overflow: hidden;
    width: 100%;
}

.login-story {
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.12), transparent 24%),
        linear-gradient(135deg, #022d39 0%, #063848 55%, #34445a 100%);
    border-radius: 8px 0 0 8px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 620px;
    padding: 34px;
}

.login-home-link {
    align-items: center;
    color: #fff;
    display: inline-flex;
    font-weight: 800;
    gap: 10px;
    text-decoration: none;
}

.login-home-link img {
    background: #fff;
    border-radius: 8px;
    height: 46px;
    object-fit: contain;
    padding: 4px;
    width: 46px;
}

.login-story h1 {
    color: #fff;
    font-size: clamp(34px, 4vw, 52px);
    margin: 0 0 16px;
    max-width: 560px;
    min-width: 0;
}

.login-story p {
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.65;
    max-width: 520px;
}

.login-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.login-highlights span {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 8px;
    display: inline-flex;
    font-weight: 800;
    gap: 8px;
    padding: 10px 12px;
}

.login-card {
    border-radius: 0 8px 8px 0;
    box-shadow: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 620px;
}

.auth-card-wide {
    width: min(100%, 720px);
}

.auth-card-wide .auth-brand {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.brand-block {
    text-align: center;
    margin-bottom: 28px;
}

.auth-brand {
    margin-bottom: 26px;
    text-align: center;
}

.brand-logo {
    display: block;
    width: min(190px, 72%);
    aspect-ratio: 1;
    object-fit: contain;
    margin: 0 auto 20px;
}

.auth-logo {
    display: block;
    height: 132px;
    margin: 0 auto 18px;
    object-fit: contain;
    width: 132px;
}

.auth-brand h2 {
    color: var(--ink);
    font-size: 32px;
    line-height: 1.1;
    margin: 0;
}

.eyebrow {
    margin: 0 0 8px;
    color: var(--accent);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

h1 {
    margin: 0;
    font-size: 32px;
    line-height: 1.1;
}

.brand-block p:last-child {
    margin: 12px 0 0;
    color: var(--muted);
    line-height: 1.5;
}

.auth-brand p:last-child {
    color: var(--muted);
    line-height: 1.5;
    margin: 12px 0 0;
}

.login-form {
    display: grid;
    gap: 12px;
}

.register-form {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.register-full {
    grid-column: 1 / -1;
}

.register-note {
    background: var(--soft-blue);
    border: 1px solid var(--line);
    border-radius: 6px;
    color: var(--ink);
    font-weight: 700;
    grid-column: 1 / -1;
    padding: 12px;
}

label {
    color: var(--ink);
    font-size: 14px;
    font-weight: 700;
}

input,
select {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 10px 12px;
    color: var(--ink);
    font-size: 16px;
}

input:focus,
select:focus {
    border-color: var(--accent);
    outline: 3px solid rgba(37, 109, 90, 0.16);
}

.hs-select-search {
    display: grid;
    gap: 6px;
}

.hs-select-search-input {
    min-height: 38px;
}

.hs-select-search-summary {
    display: block;
    font-size: 12px;
    line-height: 1.2;
    min-height: 14px;
}

button {
    min-height: 44px;
    border: 0;
    border-radius: 6px;
    background: var(--accent);
    color: #fff;
    cursor: pointer;
    font-size: 15px;
    font-weight: 700;
}

.login-form button {
    align-items: center;
    display: inline-flex;
    gap: 8px;
    justify-content: center;
}

button:hover {
    background: var(--accent-strong);
}

.secondary-button {
    border: 1px solid var(--line);
    background: var(--surface);
    color: var(--ink);
    padding: 0 16px;
}

.secondary-button:hover {
    background: #eef2ed;
}

.auth-switch {
    align-items: center;
    color: var(--muted);
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
    gap: 8px;
    justify-content: center;
    margin-top: 20px;
}

.auth-switch a {
    color: var(--accent);
    font-weight: 800;
    text-decoration: none;
}

.auth-switch a:hover {
    color: var(--accent-strong);
}

.resend-form {
    margin-top: 12px;
}

.admin-password-modal {
    border: 0;
    border-radius: 8px;
    box-shadow: 0 28px 72px rgba(2, 45, 57, 0.26);
}

.admin-password-modal .modal-header {
    background: linear-gradient(135deg, rgba(2, 45, 57, 0.08), rgba(52, 68, 90, 0.08));
}

.admin-password-modal .modal-title {
    color: var(--ink);
    font-weight: 800;
}

.admin-password-modal .form-control {
    min-height: 48px;
}

.alert {
    border-radius: 6px;
    margin-bottom: 16px;
    padding: 12px;
    font-size: 14px;
}

.alert p {
    margin: 0;
}

.alert p + p {
    margin-top: 6px;
}

.alert-error {
    background: #fff0ee;
    color: var(--danger);
}

.alert-success {
    background: #ecf8f0;
    color: var(--success);
}

@media (max-width: 720px) {
    .auth-page {
        padding: 14px;
    }

    .login-shell {
        width: 100%;
    }

    .public-home {
        padding: 18px;
        overflow: hidden;
    }

    .public-nav {
        align-items: flex-start;
        flex-direction: column;
        gap: 14px;
    }

    .public-brand span {
        max-width: 150px;
    }

    .public-nav-actions {
        justify-content: flex-start;
        width: 100%;
    }

    .public-link,
    .public-login-link,
    .primary-action,
    .secondary-action {
        min-height: 44px;
        padding: 0 14px;
    }

    .public-hero-grid {
        grid-template-columns: 1fr;
        min-height: auto;
        min-width: 0;
        padding-top: 46px;
        width: 100%;
    }

    .public-hero-copy h1 {
        font-size: 26px;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .public-hero-copy,
    .public-showcase,
    .public-services,
    .public-client-cta,
    .public-footer {
        max-width: calc(100vw - 36px);
        min-width: 0;
        width: calc(100vw - 36px);
    }

    .public-hero-copy h1,
    .public-copy {
        max-width: 100%;
    }

    .public-copy {
        font-size: 16px;
    }

    .public-actions {
        flex-direction: column;
        width: 100%;
    }

    .public-actions a {
        flex: 0 0 auto;
        width: 100%;
    }

    .public-services {
        grid-template-columns: 1fr;
    }

    .public-client-cta,
    .public-footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .public-showcase-grid {
        grid-template-columns: 1fr;
    }

    .login-experience {
        grid-template-columns: 1fr;
        max-width: 100%;
        overflow: hidden;
        width: 100%;
    }

    .login-story {
        border-radius: 8px 8px 0 0;
        min-height: auto;
        padding: 26px;
        width: 100%;
    }

    .login-story h1 {
        font-size: 28px;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .login-story p,
    .auth-brand p:last-child {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .login-highlights {
        margin-top: 28px;
    }

    .login-card {
        border-radius: 0 0 8px 8px;
        min-height: auto;
        max-width: 100%;
    }

    .register-form {
        grid-template-columns: 1fr;
    }

    .auth-card {
        padding: 24px;
    }
}

.erp-page {
    background: var(--erp-body-bg);
    color: var(--erp-text);
    font-family: "Segoe UI", Arial, sans-serif;
}

.principal-heading {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.principal-heading h1,
.page-heading h1 {
    color: var(--ink);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.05;
    margin: 0 0 6px;
}

.principal-heading p,
.page-heading p {
    color: var(--muted);
    font-size: 15px;
    margin: 0;
}

.principal-heading span {
    color: var(--accent);
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.principal-card {
    background: linear-gradient(180deg, #fff 0%, #fbfdfe 100%);
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--ink);
    display: flex;
    flex-direction: column;
    min-height: 154px;
    padding: 16px;
    text-decoration: none;
    transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.principal-card:hover,
.principal-card:focus {
    border-color: var(--accent);
    box-shadow: 0 0.5rem 1rem rgba(3, 47, 61, 0.14);
    outline: 0;
    transform: translateY(-1px);
}

.module-icon {
    align-items: center;
    background: var(--soft-blue);
    border-radius: 8px;
    color: var(--accent);
    display: inline-flex;
    flex: 0 0 38px;
    font-size: 12px;
    font-weight: 700;
    height: 38px;
    justify-content: center;
    margin-bottom: 18px;
    width: 38px;
}

.danger-icon {
    background: var(--soft-red);
    color: var(--danger);
}

.principal-card strong {
    font-size: 16px;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 9px;
}

.principal-card small {
    color: var(--muted);
    font-size: 14px;
    line-height: 1.35;
}

.principal-card em,
.maintenance-card a,
.primary-link,
.outline-link {
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    font-style: normal;
    text-decoration: none;
}

.principal-card em {
    align-self: flex-start;
    background: linear-gradient(135deg, var(--accent), var(--logo-ring));
    color: #fff;
    margin-top: auto;
    padding: 7px 10px;
}

.empty-state {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    grid-column: 1 / -1;
    padding: 20px;
}

.area-tile {
    min-height: 178px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 16px;
    height: 100%;
    padding: 20px;
    color: var(--erp-text);
    text-decoration: none;
    border-radius: 8px;
    background: var(--erp-card-bg);
    border: 1px solid var(--erp-border);
    box-shadow: 0 14px 34px rgba(30, 41, 59, 0.08);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.area-tile:hover {
    transform: translateY(-3px);
    color: var(--erp-text);
    border-color: var(--erp-navbar-bg);
    box-shadow: 0 20px 44px rgba(30, 41, 59, 0.13);
}

.area-tile-icon {
    width: 50px;
    height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-size: 1.45rem;
    background: #e8f3f7;
    color: color-mix(in srgb, var(--erp-navbar-bg) 82%, var(--erp-navbar-bg-alt) 18%);
}

.area-tile-title,
.area-tile-text,
.area-tile-status {
    display: block;
}

.area-tile-title {
    font-weight: 700;
    font-size: 1rem;
    line-height: 1.25;
    margin-bottom: 6px;
}

.area-tile-text {
    color: var(--erp-muted);
    font-size: 0.875rem;
    line-height: 1.35;
}

.area-tile-status {
    width: fit-content;
    padding: 5px 10px;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 700;
}

.area-tile-status.is-active {
    color: #fff;
    background: linear-gradient(90deg, var(--erp-navbar-bg) 0%, var(--erp-navbar-bg-alt) 100%);
}

.area-tile-status.is-muted {
    color: var(--erp-text);
    background: #eef4f6;
    border: 1px solid var(--erp-border);
}

.area-tile-administrador .area-tile-icon {
    background: #e8f3f7;
    color: #063848;
}

.area-tile-ventas .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.area-tile-finanzas .area-tile-icon {
    background: #eaf2f5;
    color: #0b4658;
}

.area-tile-agenda .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.area-tile-ventas-streaming .area-tile-icon,
.area-tile-streaming .area-tile-icon {
    background: #e8f3f7;
    color: #022d39;
}

.area-tile-streaming {
    min-height: 128px;
}

.area-tile-ventas-facturacion-electronica .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.area-tile-ventas-clientes .area-tile-icon {
    background: #e8f3f7;
    color: #022d39;
}

.area-tile-ventas-tarjetas .area-tile-icon,
.area-tile-ventas-correos .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.streaming-logo-box {
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--erp-border);
    border-radius: 8px;
    display: inline-flex;
    height: 56px;
    justify-content: center;
    padding: 10px;
    width: 132px;
}

.streaming-logo-box img {
    display: block;
    max-height: 34px;
    max-width: 108px;
    object-fit: contain;
}

.service-logo-cell {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(2, 45, 57, 0.08);
    border-radius: 4px;
    display: inline-flex;
    justify-content: center;
    min-height: 34px;
    min-width: 118px;
    padding: 4px 8px;
}

.service-logo-cell img {
    display: block;
    max-height: 28px;
    max-width: 104px;
    object-fit: contain;
}

.service-logo-cell span {
    font-weight: 600;
}

.area-tile-sistemas .area-tile-icon,
.area-tile-contabilidad .area-tile-icon,
.area-tile-facturacion .area-tile-icon,
.area-tile-inventario .area-tile-icon,
.area-tile-importaciones .area-tile-icon,
.area-tile-recepcion .area-tile-icon {
    background: #e8f3f7;
    color: #063848;
}

.area-tile-gerencia .area-tile-icon,
.area-tile-cuentas-por-cobrar .area-tile-icon,
.area-tile-mercadeo .area-tile-icon,
.area-tile-rrhh .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.area-tile-aux-bodega .area-tile-icon,
.area-tile-jefe-bodega-herramienta .area-tile-icon,
.area-tile-mantenimiento .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.area-tile-jefe-bodega-tornilleria .area-tile-icon {
    background: #eef1f5;
    color: #34445a;
}

.erp-topbar {
    align-items: center;
    background: linear-gradient(90deg, var(--erp-navbar-bg), var(--erp-navbar-bg-alt));
    color: #fff;
    display: flex;
    justify-content: space-between;
    min-height: 60px;
    padding: 10px 16px;
    box-shadow: 0 0.25rem 0.75rem rgba(3, 47, 61, 0.22);
}

.erp-brand,
.erp-session {
    align-items: center;
    display: flex;
    gap: 12px;
}

.erp-brand img {
    background: transparent;
    border-radius: 0;
    height: 38px;
    object-fit: contain;
    object-position: left center;
    padding: 0;
    width: 110px;
}

.erp-brand strong {
    color: #fff;
    font-size: 20px;
    letter-spacing: 0;
}

.erp-session {
    justify-content: flex-end;
}

.erp-session .btn {
    border-color: rgba(255, 255, 255, 0.8);
    color: #fff;
    font-weight: 500;
}

.erp-session .btn:hover,
.erp-session .btn:focus {
    background: rgba(255, 255, 255, 0.16);
    border-color: #fff;
    color: #fff;
}

.erp-user {
    color: #fff;
    line-height: 1.15;
    min-width: 180px;
    text-align: right;
}

.erp-user strong {
    display: block;
    font-size: 13px;
    text-transform: uppercase;
}

.erp-session small {
    display: block;
    color: #e8edf5;
    font-size: 12px;
}

.erp-main {
    padding-top: 24px;
}

.page-heading {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 22px;
}

.page-actions {
    display: flex;
    gap: 8px;
}

.primary-link,
.outline-link {
    display: inline-flex;
    min-height: 38px;
    align-items: center;
    padding: 0 14px;
}

.primary-link {
    background: var(--erp-accent);
    color: #fff;
}

.outline-link {
    background: transparent;
    border: 1px solid var(--erp-navbar-bg);
    color: var(--erp-navbar-bg);
    font-size: 1rem;
    font-weight: 400;
}

.outline-link:hover,
.outline-link:focus {
    background: var(--erp-navbar-bg);
    border-color: var(--erp-navbar-bg);
    color: #fff;
}

.admin-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.admin-metrics article,
.admin-panel,
.audit-panel,
.maintenance-card {
    background: var(--erp-card-bg);
    border: 1px solid var(--erp-border);
    border-radius: 8px;
}

.admin-metrics article {
    min-height: 72px;
    padding: 16px;
}

.admin-metrics span {
    color: var(--erp-muted);
    display: block;
    font-size: 14px;
    margin-bottom: 8px;
}

.admin-metrics strong {
    font-size: 28px;
    color: var(--erp-navbar-bg);
}

.admin-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(360px, 1fr);
    gap: 16px;
}

.admin-panel,
.audit-panel {
    border: 0;
    padding: 22px;
}

.panel-heading h2 {
    font-size: 20px;
    margin: 0 0 8px;
}

.panel-heading p {
    color: var(--erp-muted);
    margin: 0 0 22px;
}

.client-account-locator-result {
    display: grid;
    gap: 8px;
}

.client-account-locator-item {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(180px, 1.2fr) minmax(180px, 1fr) minmax(160px, .9fr);
    gap: 12px;
    align-items: center;
    text-align: left;
    border: 1px solid var(--erp-border);
    border-radius: 8px;
    background: #f8fbfc;
    color: var(--erp-text);
    padding: 10px 12px;
}

.client-account-locator-item:hover {
    border-color: color-mix(in srgb, var(--erp-primary) 45%, var(--erp-border));
    background: #eef7fa;
}

.client-account-locator-item span {
    display: grid;
    min-width: 0;
}

.client-account-locator-item small {
    color: var(--erp-muted);
    overflow-wrap: anywhere;
}

@media (max-width: 768px) {
    .client-account-locator-item {
        grid-template-columns: 1fr;
    }
}

.maintenance-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.maintenance-card {
    min-height: 148px;
    padding: 16px;
    color: var(--erp-text);
    display: block;
    text-decoration: none;
    transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.maintenance-card:hover,
.maintenance-card:focus {
    border-color: var(--erp-navbar-bg);
    box-shadow: 0 20px 44px rgba(30, 41, 59, 0.13);
    color: var(--erp-text);
    outline: 0;
    transform: translateY(-2px);
}

.maintenance-card h3 {
    font-size: 16px;
    margin: 0 0 8px;
}

.maintenance-card p {
    color: var(--erp-muted);
    font-size: 14px;
    line-height: 1.35;
    margin: 0 0 16px;
}

.maintenance-card-action {
    background: linear-gradient(90deg, var(--erp-navbar-bg) 0%, var(--erp-accent) 100%);
    border-radius: 6px;
    color: #fff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 700;
    padding: 7px 10px;
}

.audit-list a {
    align-items: center;
    border-bottom: 1px solid var(--erp-border);
    color: var(--erp-text);
    display: flex;
    gap: 14px;
    padding: 11px 0;
    text-decoration: none;
}

.audit-list a:last-child {
    border-bottom: 0;
}

.audit-list .module-icon {
    margin-bottom: 0;
}

.audit-list strong,
.audit-list small {
    display: block;
}

.audit-list small {
    color: var(--erp-muted);
    margin-top: 5px;
}

.theme-panel {
    min-width: 300px;
    border: 0;
    border-radius: 8px;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.18);
}

.theme-swatch {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    border: 1px solid rgba(15, 23, 42, 0.14);
}

.theme-option {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    border: 0;
    background: transparent;
    padding: 8px 6px;
    border-radius: 8px;
    text-align: left;
}

.theme-option:hover {
    background: rgba(15, 23, 42, 0.06);
}

.theme-color-input {
    width: 48px;
    min-width: 48px;
    height: 36px;
    padding: 3px;
}

.admin-confirm-modal {
    border: 0;
    border-radius: 8px;
    box-shadow: 0 24px 80px rgba(2, 45, 57, 0.22);
}

.admin-confirm-modal .modal-title {
    color: var(--erp-text);
    font-weight: 800;
}

.modal-hs-wide {
    --bs-modal-width: 96vw;
    max-width: 96vw;
    width: 96vw;
}

.modal-hs-wide .modal-body {
    overflow: visible;
}

.modal-hs-wide .table {
    font-size: 0.875rem;
}

.assigned-client-actions-cell {
    min-width: 286px;
    white-space: nowrap;
}

.assigned-client-actions {
    align-items: center;
    display: inline-flex;
    flex-wrap: nowrap;
    gap: 0.25rem;
    justify-content: flex-end;
}

.assigned-client-actions form,
.assigned-client-actions .js-quick-payment-form {
    align-items: center;
    display: inline-flex !important;
    flex-wrap: nowrap;
    gap: 0.25rem;
    margin: 0;
}

.assigned-client-actions .action-icon-btn {
    align-items: center;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    padding: 0;
    width: 32px;
}

.assigned-client-actions .quick-payment-amount {
    flex: 0 0 68px;
    width: 68px;
}

.modal-hs-wide .form-label {
    min-height: 34px;
}

.btn-primary {
    --bs-btn-bg: var(--erp-navbar-bg);
    --bs-btn-border-color: var(--erp-navbar-bg);
    --bs-btn-hover-bg: color-mix(in srgb, var(--erp-navbar-bg) 88%, #000 12%);
    --bs-btn-hover-border-color: color-mix(in srgb, var(--erp-navbar-bg) 88%, #000 12%);
    --bs-btn-active-bg: color-mix(in srgb, var(--erp-navbar-bg) 82%, #000 18%);
    --bs-btn-active-border-color: color-mix(in srgb, var(--erp-navbar-bg) 82%, #000 18%);
}

.btn-outline-primary {
    --bs-btn-color: var(--erp-navbar-bg);
    --bs-btn-border-color: var(--erp-navbar-bg);
    --bs-btn-hover-bg: var(--erp-navbar-bg);
    --bs-btn-hover-border-color: var(--erp-navbar-bg);
    --bs-btn-active-bg: var(--erp-navbar-bg);
    --bs-btn-active-border-color: var(--erp-navbar-bg);
}

.text-bg-primary {
    background-color: var(--erp-navbar-bg) !important;
}

.balance-favor-badge {
    background-color: #0d6efd !important;
    color: #ffffff !important;
}

.balance-debt-badge {
    background-color: #dc3545 !important;
    color: #ffffff !important;
}

.balance-zero-badge {
    background-color: #198754 !important;
    color: #ffffff !important;
}

.text-bg-danger,
.btn-danger {
    background-color: var(--erp-accent) !important;
    border-color: var(--erp-accent) !important;
}

.badge-invalidado,
.dte-status-invalidado {
    background: #b42318 !important;
    border: 1px solid #8f1d14 !important;
    color: #ffffff !important;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08);
    font-weight: 800;
}

.dte-documents-table {
    --dte-row-base: #ffffff;
    --dte-row-alt: color-mix(in srgb, var(--erp-navbar-bg) 7%, #ffffff 93%);
    --dte-row-hover: color-mix(in srgb, var(--erp-navbar-bg) 12%, #ffffff 88%);
}

.dte-documents-table thead th {
    background: color-mix(in srgb, var(--erp-navbar-bg) 8%, #ffffff 92%);
    color: var(--erp-text);
    font-weight: 800;
}

.dte-documents-table .dte-document-row > td {
    background: var(--dte-row-base);
}

.dte-documents-table .dte-document-row-alt > td {
    background: var(--dte-row-alt);
}

.dte-documents-table.table-hover > tbody > tr:hover > * {
    background: var(--dte-row-hover);
}

.dte-locked-select {
    pointer-events: none;
    background-color: var(--bs-secondary-bg);
}

.dte-adjust-line {
    align-items: center;
    background: color-mix(in srgb, var(--erp-navbar-bg) 10%, #ffffff 90%);
    border: 1px solid color-mix(in srgb, var(--erp-navbar-bg) 22%, #ffffff 78%);
    border-radius: 8px;
    color: var(--erp-text);
    display: inline-flex;
    font-size: 0.82rem;
    font-weight: 800;
    gap: 0.45rem;
    padding: 0.35rem 0.55rem;
    cursor: pointer;
    transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.dte-adjust-line .form-check-input {
    float: none;
    margin: 0;
}

.dte-adjust-line:has(.form-check-input:checked) {
    background: var(--erp-navbar-bg);
    border-color: var(--erp-navbar-bg);
    color: #ffffff;
}

.dte-adjust-line:hover {
    transform: translateY(-1px);
}

.dte-adjust-title {
    min-width: 48px;
}

.dte-original-line {
    color: var(--erp-text) !important;
    font-weight: 700;
}

.cobros-table-wrap {
    overflow: visible !important;
}

.cobros-table-wrap .dropdown {
    position: static;
}

.cobros-table-wrap .dropdown-menu {
    z-index: 1100;
}

.cobros-table-wrap tbody tr.cobro-client-row > td,
.cobros-table-wrap tbody tr.cobro-client-summary > td {
    border-top-color: rgba(2, 45, 57, 0.12);
}

.cobros-table-wrap tbody tr.cobro-client-band-a > td {
    background: #f7fbfc;
}

.cobros-table-wrap tbody tr.cobro-client-band-b > td {
    background: #edf5f7;
}

.cobros-table-wrap tbody tr.cobro-client-summary > td {
    border-top: 2px solid rgba(2, 45, 57, 0.2);
    font-weight: 700;
}

.cobros-table-wrap tbody tr.cobro-client-band-a > td:first-child {
    box-shadow: inset 4px 0 #0d6efd;
}

.cobros-table-wrap tbody tr.cobro-client-band-b > td:first-child {
    box-shadow: inset 4px 0 #198754;
}

.cobros-table-wrap.table-hover tbody tr.cobro-client-row:hover > *,
.cobros-table-wrap .table-hover tbody tr.cobro-client-row:hover > * {
    background: #e2f0f4;
}

@media (max-width: 720px) {
    .login-panel {
        padding: 24px;
    }

    .admin-metrics,
    .admin-layout,
    .maintenance-grid {
        grid-template-columns: 1fr;
    }

    .principal-heading,
    .page-heading,
    .erp-topbar,
    .erp-session {
        align-items: flex-start;
        flex-direction: column;
    }

    .erp-brand img {
        width: 92px;
    }

    .erp-user {
        min-width: 0;
        text-align: left;
    }

    .page-actions {
        flex-wrap: wrap;
    }
}
