:root {
    --colmena-primary: #06203F;
    --colmena-primary-soft: #0B2E59;
    --colmena-accent: #F5B400;
    --colmena-bg: #F4F7FB;
    --colmena-card: #FFFFFF;
    --colmena-text: #1F2937;
    --colmena-muted: #6B7280;
    --colmena-border: #E5E7EB;
    --colmena-radius: 18px;
}

body {
    background: var(--colmena-bg) !important;
    color: var(--colmena-text);
    font-family: "Open Sans", Arial, sans-serif;
}

section#main-body {
    background: var(--colmena-bg) !important;
    padding-top: 48px;
    padding-bottom: 64px;
}

.navbar-main {
    background: #ffffff !important;
    border: 0 !important;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

.navbar-main .navbar-nav > li > a {
    color: var(--colmena-primary) !important;
    font-weight: 600;
}

.navbar-main .navbar-nav > li > a:hover,
.navbar-main .navbar-nav > li > a:focus {
    background: rgba(6, 32, 63, 0.06) !important;
    color: var(--colmena-primary) !important;
}

.header-lined h1,
h1,
h2,
h3 {
    color: var(--colmena-primary);
}

.logincontainer,
.card,
.panel,
.client-home-panels .panel {
    border: 1px solid var(--colmena-border) !important;
    border-radius: var(--colmena-radius) !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08) !important;
    overflow: hidden;
}



.form-control {
    
    border-color: #D1D5DB !important;
    min-height: 42px;
}

.input-group-text,
.input-group-addon {
    border-radius: 12px 0 0 12px !important;
    background: #F3F6FA !important;
    border-color: #D1D5DB !important;
    color: var(--colmena-primary) !important;
}

.btn,
button {
    border-radius: 12px !important;
    font-weight: 600;
}

.btn-primary,
.btn-success {
    background: var(--colmena-primary) !important;
    border-color: var(--colmena-primary) !important;
}

.btn-primary:hover,
.btn-success:hover {
    background: var(--colmena-primary-soft) !important;
    border-color: var(--colmena-primary-soft) !important;
}

.btn-warning {
    background: var(--colmena-accent) !important;
    border-color: var(--colmena-accent) !important;
    color: var(--colmena-primary) !important;
}

.main-content {
    background: transparent !important;
}

.table,
.dataTables_wrapper {
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
}

.label,
.badge {
    border-radius: 999px !important;
    padding: 6px 10px !important;
}

footer.footer {
    background: var(--colmena-primary) !important;
    color: #ffffff !important;
    border: 0 !important;
    padding: 42px 0 !important;
}

footer.footer a {
    color: #ffffff !important;
}

footer.footer .copyright {
    color: rgba(255,255,255,0.85) !important;
}

#btn-to-top,
.back-to-top {
    display: none !important;
}


/* Colmena - Ocultar accesos de hosting que no aplican al residente */
.client-home-panels .btn-group,
.client-home-panels a[href*="cpanel"],
.client-home-panels a[href*="server"],
.client-home-panels a[href*="clientarea.php?action=services"],
.client-home-panels a[href*="cart.php"] {
    display: none !important;
}



/* Colmena - Dashboard residente */
.client-home-panels .panel-heading,
.panel-heading {
    background: #ffffff !important;
    color: var(--colmena-primary) !important;
    font-weight: 700;
}

.client-home-panels .panel-title,
.panel-title {
    color: var(--colmena-primary) !important;
    font-weight: 700;
}

.tiles .tile {
    background: #ffffff !important;
    border-radius: 18px !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07) !important;
    border: 1px solid #E5E7EB !important;
}

.tiles .tile .icon {
    opacity: 0.18 !important;
}

.tiles .tile .stat {
    color: var(--colmena-primary) !important;
}

.tiles .tile .title {
    color: var(--colmena-muted) !important;
    font-weight: 700;
    letter-spacing: .02em;
}

.home-kb-search {
    display: none !important;
}

/* ==========================================================
   Colmena - Login moderno con login.tpl propio
   ========================================================== */

body.colmena-login-page {
    background: #ffffff !important;
    overflow-x: hidden;
}

body.colmena-login-page header,
body.colmena-login-page .navbar,
body.colmena-login-page .navbar-main,
body.colmena-login-page .topbar,
body.colmena-login-page .master-breadcrumb,
body.colmena-login-page footer.footer,
body.colmena-login-page .adminreturndiv,
body.colmena-login-page .btn-return-to-admin,
body.colmena-login-page a[href*="returntoadmin"] {
    display: none !important;
}

body.colmena-login-page section#main-body {
    min-height: 100vh;
    padding: 0 !important;
    background: #ffffff !important;
    position: relative;
    overflow: hidden;
}

body.colmena-login-page section#main-body:before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 42%;
    height: 100vh;
    background:
        radial-gradient(circle at 18% 8%, rgba(255,255,255,0.14) 0, rgba(255,255,255,0) 28%),
        linear-gradient(160deg, #06203F 0%, #123F7A 58%, #15529F 100%);
    z-index: 0;
}

body.colmena-login-page section#main-body:after {
    content: "Bienvenido a Colmena\A\A Consulta tus facturas, realiza pagos, revisa consumos y abre solicitudes desde un solo lugar.\A\A Un portal privado para residentes, simple, seguro y fácil de usar.";
    white-space: pre-line;
    position: fixed;
    left: 5%;
    top: 30%;
    width: 30%;
    color: #ffffff;
    font-size: 19px;
    line-height: 1.75;
    font-weight: 400;
    z-index: 1;
}

body.colmena-login-page section#main-body > .container:before {
    content: "";
    position: fixed;
    left: 5%;
    top: 58px;
    width: 300px;
    height: 80px;
    background-image: url("/templates/colmena/img/Colmena-Logo-WHMCS-Login.png");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left center;
    z-index: 3;
}

body.colmena-login-page section#main-body > .container {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    position: relative;
    z-index: 2;
}

body.colmena-login-page section#main-body > .container > .row {
    width: 100%;
    min-height: 100vh;
    margin: 0 !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.colmena-login-page section#main-body > .container > .row > .primary-content {
    width: 58% !important;
    max-width: 58% !important;
    flex: 0 0 58% !important;
    min-height: 100vh;
    margin-left: 42% !important;
    padding: 60px 80px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.colmena-login-page .colmena-login-shell {
    width: 100%;
    display: flex;
    justify-content: center;
}

body.colmena-login-page .colmena-login-form {
    width: 100%;
    max-width: 520px;
}

body.colmena-login-page .colmena-login-card {
    width: 100%;
    background: #ffffff;
    border: 1px solid #E5EAF2;
    border-radius: 28px;
    box-shadow: 0 34px 90px rgba(15, 23, 42, 0.12);
    overflow: hidden;
}

body.colmena-login-page .colmena-login-card-body {
    padding: 44px 46px 38px;
}

body.colmena-login-page .colmena-login-heading {
    margin-bottom: 30px;
}

body.colmena-login-page .colmena-login-kicker {
    display: inline-flex;
    margin-bottom: 12px;
    color: #124A9C;
    background: rgba(18, 74, 156, 0.08);
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.02em;
}

body.colmena-login-page .colmena-login-heading h1 {
    margin: 0 0 10px;
    color: #0F172A;
    font-size: 34px;
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.035em;
}

body.colmena-login-page .colmena-login-heading p {
    margin: 0;
    color: #64748B;
    font-size: 15px;
    line-height: 1.6;
}

body.colmena-login-page .colmena-form-group {
    margin-bottom: 20px;
}

body.colmena-login-page .colmena-form-group label {
    display: block;
    color: #1E293B;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 9px;
}

body.colmena-login-page .colmena-password-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

body.colmena-login-page .colmena-forgot-link {
    color: #124A9C !important;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
}

body.colmena-login-page .colmena-forgot-link:hover {
    text-decoration: underline;
}

body.colmena-login-page .colmena-input-group {
    display: flex !important;
    width: 100%;
}

body.colmena-login-page .colmena-input-group .input-group-prepend,
body.colmena-login-page .colmena-input-group .input-group-append {
    display: flex !important;
}

body.colmena-login-page .colmena-input-group .input-group-text {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    height: 54px;
    background: #F8FAFC !important;
    border: 1px solid #D8E0EA !important;
    color: #06203F !important;
    border-radius: 14px 0 0 14px !important;
}

body.colmena-login-page .colmena-input-group .form-control {
    width: 100% !important;
    min-height: 54px !important;
    height: 54px !important;
    border: 1px solid #D8E0EA !important;
    background: #ffffff !important;
    color: #0F172A;
    box-shadow: none !important;
    font-size: 15px !important;
    border-radius: 0 14px 14px 0 !important;
}

body.colmena-login-page .colmena-input-group .form-control:focus {
    border-color: #124A9C !important;
    box-shadow: 0 0 0 4px rgba(18, 74, 156, 0.10) !important;
}

body.colmena-login-page .colmena-reveal-pw {
    height: 54px !important;
    min-width: 52px !important;
    border-radius: 0 14px 14px 0 !important;
    border: 1px solid #D8E0EA !important;
    background: #ffffff !important;
    color: #334155 !important;
}

body.colmena-login-page .colmena-captcha-wrap {
    margin: 18px 0 22px;
}

body.colmena-login-page .colmena-login-actions {
    margin-top: 8px;
}

body.colmena-login-page .colmena-login-button {
    display: block !important;
    width: 100% !important;
    min-height: 56px !important;
    background: #06203F !important;
    border-color: #06203F !important;
    color: #ffffff !important;
    border-radius: 14px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    box-shadow: 0 14px 26px rgba(6, 32, 63, 0.22);
}

body.colmena-login-page .colmena-login-button:hover {
    background: #0B2E59 !important;
    border-color: #0B2E59 !important;
}

body.colmena-login-page .colmena-remember {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 18px 0 0;
    color: #475569;
    font-size: 14px;
    font-weight: 500;
}

body.colmena-login-page .colmena-remember input {
    margin: 0 !important;
    width: 16px;
    height: 16px;
}

body.colmena-login-page .colmena-login-card-footer {
    background: #F8FAFC;
    border-top: 1px solid #E7ECF3;
    padding: 22px 46px;
    text-align: center;
    font-size: 14px;
    color: #64748B;
}

body.colmena-login-page .colmena-login-card-footer a {
    margin-left: 6px;
    color: #124A9C !important;
    font-weight: 800;
    text-decoration: none;
}

body.colmena-login-page .colmena-login-card-footer a:hover {
    text-decoration: underline;
}

body.colmena-login-page .primary-content > p,
body.colmena-login-page p.text-center,
body.colmena-login-page p.text-muted,
body.colmena-login-page .powered-by,
body.colmena-login-page .poweredby {
    display: none !important;
}

@media (max-width: 991px) {
    body.colmena-login-page section#main-body:before,
    body.colmena-login-page section#main-body:after {
        display: none !important;
    }

    body.colmena-login-page section#main-body > .container:before {
        display: block !important;
        content: "";
        position: relative;
        left: auto;
        top: auto;
        width: 300px;
        height: 90px;
        margin: 28px auto 18px;
        background-image: url("/templates/colmena/img/Colmena-Logo-dark.png");
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
        filter: none;
        z-index: 3;
    }

    body.colmena-login-page section#main-body {
        background: #F4F7FB !important;
    }

    body.colmena-login-page section#main-body > .container > .row > .primary-content {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        margin-left: 0 !important;
        padding: 24px !important;
    }

    body.colmena-login-page .colmena-login-card {
        border-radius: 22px;
    }

    body.colmena-login-page .colmena-login-card-body {
        padding: 34px 28px 30px;
    }

    body.colmena-login-page .colmena-login-heading h1 {
        font-size: 28px;
    }

    body.colmena-login-page .colmena-login-card-footer {
        padding: 18px 28px;
    }
}

/* ==========================================================
   Colmena - Fix final input groups login
   ========================================================== */

body.colmena-login-page .colmena-input-group {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
}

body.colmena-login-page .colmena-input-group .input-group-prepend,
body.colmena-login-page .colmena-input-group .input-group-append {
    display: flex !important;
    flex: 0 0 auto !important;
    width: auto !important;
}

body.colmena-login-page .colmena-input-group .input-group-text {
    width: 52px !important;
    min-width: 52px !important;
    height: 54px !important;
    border-radius: 14px 0 0 14px !important;
}

body.colmena-login-page .colmena-input-group .form-control {
    flex: 1 1 auto !important;
    width: 1% !important;
    min-width: 0 !important;
    height: 54px !important;
    min-height: 54px !important;
}

body.colmena-login-page .colmena-input-group .input-group-prepend + .form-control {
    border-left: 0 !important;
    border-radius: 0 14px 14px 0 !important;
}

body.colmena-login-page .colmena-input-group .form-control.pw-input {
    border-left: 0 !important;
    border-right: 0 !important;
    border-radius: 0 !important;
}

body.colmena-login-page .colmena-input-group .input-group-append .btn,
body.colmena-login-page .colmena-reveal-pw {
    width: 52px !important;
    min-width: 52px !important;
    height: 54px !important;
    border-radius: 0 14px 14px 0 !important;
}

body.colmena-login-page .colmena-login-card {
    max-width: 540px !important;
}

body.colmena-login-page .colmena-login-form {
    max-width: 540px !important;
}


/* ==========================================================
   Colmena - Corrección definitiva de inputs del login
   ========================================================== */

body.colmena-login-page .colmena-input-group {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
}

body.colmena-login-page .colmena-input-group .input-group-prepend,
body.colmena-login-page .colmena-input-group .input-group-append {
    display: flex !important;
    flex: 0 0 52px !important;
    width: 52px !important;
    max-width: 52px !important;
}

body.colmena-login-page .colmena-input-group .input-group-text {
    width: 52px !important;
    min-width: 52px !important;
    max-width: 52px !important;
    height: 54px !important;
    min-height: 54px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 14px 0 0 14px !important;
    border: 1px solid #D8E0EA !important;
    background: #F8FAFC !important;
    color: #06203F !important;
}

body.colmena-login-page .colmena-input-group .form-control {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 54px !important;
    min-height: 54px !important;
    border: 1px solid #D8E0EA !important;
    border-left: 0 !important;
    background: #ffffff !important;
    box-shadow: none !important;
    border-radius: 0 14px 14px 0 !important;
}

body.colmena-login-page .colmena-input-group .form-control.pw-input {
    border-radius: 0 !important;
    border-right: 0 !important;
}

body.colmena-login-page .colmena-input-group .input-group-append .btn,
body.colmena-login-page .colmena-reveal-pw {
    width: 52px !important;
    min-width: 52px !important;
    max-width: 52px !important;
    height: 54px !important;
    min-height: 54px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 0 14px 14px 0 !important;
    border: 1px solid #D8E0EA !important;
    background: #ffffff !important;
    color: #334155 !important;
}

/* ==========================================================
   Colmena - Área de cliente base
   ========================================================== */

body:not(.colmena-login-page) section#main-body {
    background: #F4F7FB !important;
    padding-top: 56px !important;
    padding-bottom: 72px !important;
}

body:not(.colmena-login-page) .primary-content {
    max-width: 1120px;
}

body:not(.colmena-login-page) .sidebar .panel,
body:not(.colmena-login-page) .client-home-panels .panel,
body:not(.colmena-login-page) .tiles .tile {
    border: 1px solid #E6ECF3 !important;
    border-radius: 20px !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06) !important;
    overflow: hidden;
}

body:not(.colmena-login-page) .tiles {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 22px;
}

body:not(.colmena-login-page) .tiles .tile {
    width: auto !important;
    min-height: 112px;
    padding: 20px !important;
    background: #ffffff !important;
}

body:not(.colmena-login-page) .tiles .tile .stat {
    color: #06203F !important;
    font-size: 36px !important;
    font-weight: 700 !important;
}

body:not(.colmena-login-page) .tiles .tile .title {
    color: #64748B !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
}

body:not(.colmena-login-page) .tiles .tile .icon {
    opacity: 0.16 !important;
}

body:not(.colmena-login-page) .panel-heading {
    background: #ffffff !important;
    border-bottom: 1px solid #E6ECF3 !important;
    color: #06203F !important;
    font-weight: 800 !important;
    padding: 16px 18px !important;
}

body:not(.colmena-login-page) .panel-body {
    padding: 18px !important;
}

body:not(.colmena-login-page) .panel-footer {
    background: #F8FAFC !important;
    border-top: 1px solid #E6ECF3 !important;
}

body:not(.colmena-login-page) .btn-primary,
body:not(.colmena-login-page) .btn-success {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #ffffff !important;
}

body:not(.colmena-login-page) .btn-warning {
    background: #F5B400 !important;
    border-color: #F5B400 !important;
    color: #06203F !important;
}

body:not(.colmena-login-page) .client-home-panels .btn-group,
body:not(.colmena-login-page) a[href*="cpanel"],
body:not(.colmena-login-page) a[href*="server"],
body:not(.colmena-login-page) a[href*="cart.php?a=add"],
body:not(.colmena-login-page) a[href*="cart.php"] {
    display: none !important;
}

body:not(.colmena-login-page) .sidebar .list-group-item[href*="cart.php"],
body:not(.colmena-login-page) .sidebar a[href*="cart.php"] {
    display: none !important;
}

@media (max-width: 991px) {
    body:not(.colmena-login-page) .tiles {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575px) {
    body:not(.colmena-login-page) .tiles {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================
   Colmena - Dashboard área de cliente
   ========================================================== */

body:not(.colmena-login-page) .colmena-client-dashboard {
    max-width: 1120px;
    margin: 0 auto;
}

body:not(.colmena-login-page) .colmena-dashboard-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
}

body:not(.colmena-login-page) .colmena-dashboard-kicker {
    display: inline-flex;
    margin-bottom: 10px;
    color: #124A9C;
    background: rgba(18, 74, 156, 0.08);
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 800;
}

body:not(.colmena-login-page) .colmena-dashboard-heading h1 {
    margin: 0;
    color: #0F172A;
    font-size: 36px;
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.04em;
}

body:not(.colmena-login-page) .colmena-dashboard-heading p {
    margin: 10px 0 0;
    color: #64748B;
    font-size: 15px;
}

body:not(.colmena-login-page) .colmena-dashboard-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

body:not(.colmena-login-page) .colmena-btn-primary,
body:not(.colmena-login-page) .colmena-btn-light {
    min-height: 42px;
    border-radius: 12px !important;
    padding: 10px 16px;
    font-weight: 800;
}

body:not(.colmena-login-page) .colmena-btn-primary {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #ffffff !important;
}

body:not(.colmena-login-page) .colmena-btn-light {
    background: #ffffff !important;
    border: 1px solid #D8E0EA !important;
    color: #06203F !important;
}

body:not(.colmena-login-page) .colmena-alert {
    display: flex;
    align-items: center;
    gap: 14px;
    border-radius: 18px;
    padding: 16px 18px;
    margin-bottom: 22px;
}

body:not(.colmena-login-page) .colmena-alert-warning {
    background: #FFF7E6;
    border: 1px solid #FED7AA;
    color: #9A3412;
}

body:not(.colmena-login-page) .colmena-alert-icon {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FFEDD5;
    color: #EA580C;
    flex: 0 0 auto;
}

body:not(.colmena-login-page) .colmena-alert-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 3px;
    font-size: 14px;
}

body:not(.colmena-login-page) .colmena-alert-link {
    color: #EA580C;
    font-weight: 800;
    text-decoration: none;
}

body:not(.colmena-login-page) .colmena-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

body:not(.colmena-login-page) .colmena-summary-card {
    position: relative;
    display: block;
    min-height: 148px;
    background: #ffffff;
    border: 1px solid #E6ECF3;
    border-radius: 22px;
    padding: 22px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
    text-decoration: none !important;
    overflow: hidden;
}

body:not(.colmena-login-page) .colmena-summary-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 55px rgba(15, 23, 42, 0.09);
}

body:not(.colmena-login-page) .colmena-summary-icon {
    position: absolute;
    right: 22px;
    top: 20px;
    color: #CBD5E1;
    font-size: 34px;
}

body:not(.colmena-login-page) .colmena-summary-number {
    color: #06203F;
    font-size: 42px;
    line-height: 1;
    font-weight: 800;
    margin-top: 34px;
}

body:not(.colmena-login-page) .colmena-summary-label {
    margin-top: 10px;
    color: #64748B;
    font-size: 13px;
    font-weight: 800;
}

body:not(.colmena-login-page) .colmena-dashboard-panels {
    display: block;
}

body:not(.colmena-login-page) .colmena-panel-wide {
    margin-bottom: 20px;
}

body:not(.colmena-login-page) .colmena-panel-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

body:not(.colmena-login-page) .colmena-panel {
    background: #ffffff !important;
    border: 1px solid #E6ECF3 !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06) !important;
    overflow: hidden;
    margin-bottom: 0 !important;
}

body:not(.colmena-login-page) .colmena-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #ffffff !important;
    border-bottom: 1px solid #E6ECF3 !important;
    padding: 16px 18px !important;
}

body:not(.colmena-login-page) .colmena-panel-title {
    color: #06203F !important;
    font-size: 16px !important;
    font-weight: 800 !important;
}

body:not(.colmena-login-page) .colmena-panel-body {
    padding: 18px !important;
    color: #334155;
}

body:not(.colmena-login-page) .colmena-panel-list .list-group-item {
    border-left: 0 !important;
    border-right: 0 !important;
    border-color: #E6ECF3 !important;
    padding: 14px 18px !important;
}

body:not(.colmena-login-page) .colmena-panel-list .list-group-item:first-child {
    border-top: 0 !important;
}

body:not(.colmena-login-page) .colmena-panel-list .list-group-item:last-child {
    border-bottom: 0 !important;
}

body:not(.colmena-login-page) .colmena-panel-footer {
    background: #F8FAFC !important;
    border-top: 1px solid #E6ECF3 !important;
    padding: 12px 18px !important;
}

body:not(.colmena-login-page) .colmena-panel-btn {
    border-radius: 999px !important;
    font-weight: 800;
}

body:not(.colmena-login-page) a[href*="cpanel"],
body:not(.colmena-login-page) a[href*="server"] {
    display: none !important;
}

@media (max-width: 991px) {
    body:not(.colmena-login-page) .colmena-dashboard-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    body:not(.colmena-login-page) .colmena-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body:not(.colmena-login-page) .colmena-panel-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575px) {
    body:not(.colmena-login-page) .colmena-summary-grid {
        grid-template-columns: 1fr;
    }

    body:not(.colmena-login-page) .colmena-dashboard-heading h1 {
        font-size: 30px;
    }
}





/* ==========================================================
   Colmena - Limpieza de elementos que no aplican
   ========================================================== */

body:not(.colmena-login-page) a[href*="affiliates.php"],
body:not(.colmena-login-page) a[href*="cart.php"],
body:not(.colmena-login-page) a[href*="cart.php?a=add"],
body:not(.colmena-login-page) a[href*="cpanel"],
body:not(.colmena-login-page) a[href*="server"] {
    display: none !important;
}

body:not(.colmena-login-page) .sidebar a[href*="cart.php"],
body:not(.colmena-login-page) .sidebar a[href*="affiliates.php"] {
    display: none !important;
}

body:not(.colmena-login-page) .colmena-panel a[href*="cpanel"],
body:not(.colmena-login-page) .colmena-panel .dropdown-toggle {
    display: none !important;
}


/* Colmena - Limpieza segura de elementos que no aplican */
body:not(.colmena-login-page) a[href*="cpanel"],
body:not(.colmena-login-page) a[href*="server"] {
    display: none !important;
}

body:not(.colmena-login-page) .sidebar a[href*="cart.php"],
body:not(.colmena-login-page) .sidebar a[href*="affiliates.php"] {
    display: none !important;
}

/* Colmena - Ocultar botón Ingresar a cPanel en servicios */
body:not(.colmena-login-page) button[data-identifier="cpanel"],
body:not(.colmena-login-page) button[data-identifier*="cpanel"],
body:not(.colmena-login-page) .btn-custom-action[data-identifier="cpanel"],
body:not(.colmena-login-page) .btn-custom-action[data-identifier*="cpanel"] {
    display: none !important;
}


/* ==========================================================
   Colmena - Layout SaaS para cliente logueado
   ========================================================== */

body.colmena-client-page {
    background: #F4F7FB !important;
}

body.colmena-client-page header#header,
body.colmena-client-page .master-breadcrumb {
    display: none !important;
}

body.colmena-client-page .colmena-app-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 248px;
    height: 100vh;
    background: #ffffff;
    border-right: 1px solid #E6ECF3;
    box-shadow: 12px 0 35px rgba(15, 23, 42, 0.04);
    z-index: 1000;
    display: flex;
    flex-direction: column;
}

body.colmena-client-page .colmena-app-logo {
    height: 92px;
    display: flex;
    align-items: center;
    padding: 0 28px;
    border-bottom: 1px solid #EEF2F7;
}

body.colmena-client-page .colmena-app-logo img {
    max-width: 170px;
    height: auto;
    display: block;
}

body.colmena-client-page .colmena-app-nav {
    padding: 22px 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

body.colmena-client-page .colmena-app-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 46px;
    padding: 0 14px;
    border-radius: 14px;
    color: #334155;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 700;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-app-nav-item i {
    width: 22px;
    text-align: center;
    color: #124A9C;
    font-size: 16px;
}

body.colmena-client-page .colmena-app-nav-item:hover {
    background: rgba(18, 74, 156, 0.08);
    color: #06203F;
}

body.colmena-client-page .colmena-app-nav-item:first-child {
    background: rgba(18, 74, 156, 0.12);
    color: #06203F;
}

body.colmena-client-page .colmena-app-sidebar-footer {
    margin-top: auto;
    padding: 16px 14px 22px;
    border-top: 1px solid #EEF2F7;
}

body.colmena-client-page .colmena-logout {
    color: #B91C1C !important;
}

body.colmena-client-page .colmena-logout i {
    color: #B91C1C !important;
}

body.colmena-client-page .colmena-app-topbar {
    position: fixed;
    top: 0;
    left: 248px;
    right: 0;
    height: 72px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid #E6ECF3;
    z-index: 999;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 38px;
}

body.colmena-client-page .colmena-app-topbar-title span {
    color: #64748B;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

body.colmena-client-page .colmena-app-topbar-actions {
    display: flex;
    align-items: center;
    gap: 16px;
}

body.colmena-client-page .colmena-app-topbar-actions a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #334155;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 700;
}

body.colmena-client-page .colmena-app-topbar-actions a:hover {
    color: #06203F;
}

body.colmena-client-page .colmena-app-topbar-actions .fa-whatsapp {
    color: #25D366;
}

body.colmena-client-page section#main-body {
    margin-left: 248px;
    padding-top: 118px !important;
    min-height: calc(100vh - 220px);
}

body.colmena-client-page section#main-body > .container {
    max-width: 1180px;
}

body.colmena-client-page footer.footer {
    margin-left: 248px;
}

body.colmena-client-page .btn-return-to-admin {
    display: none !important;
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-app-sidebar {
        transform: translateX(-100%);
    }

    body.colmena-client-page .colmena-app-topbar {
        left: 0;
        padding: 0 20px;
    }

    body.colmena-client-page .colmena-app-topbar-title {
        display: none;
    }

    body.colmena-client-page .colmena-app-topbar-actions {
        width: 100%;
        justify-content: flex-end;
        gap: 12px;
    }

    body.colmena-client-page .colmena-app-topbar-actions a {
        font-size: 12px;
    }

    body.colmena-client-page section#main-body {
        margin-left: 0;
        padding-top: 104px !important;
    }

    body.colmena-client-page footer.footer {
        margin-left: 0;
    }
}


/* ==========================================================
   Colmena - Refinamiento layout cliente
   ========================================================== */

body.colmena-client-page section#main-body > .container > .row > .col-lg-4,
body.colmena-client-page section#main-body > .container > .row > .col-xl-3 {
    display: none !important;
}

body.colmena-client-page section#main-body > .container > .row > .primary-content,
body.colmena-client-page section#main-body > .container > .row > .col-lg-8,
body.colmena-client-page section#main-body > .container > .row > .col-xl-9 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
}

body.colmena-client-page .colmena-client-dashboard {
    max-width: 1040px;
    margin: 0 auto;
}

body.colmena-client-page section#main-body {
    padding-top: 112px !important;
}

body.colmena-client-page footer.footer {
    display: none !important;
}

/* ==========================================================
   Colmena - Tarjeta superior del residente
   ========================================================== */

body.colmena-client-page .colmena-resident-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    background: linear-gradient(135deg, #06203F 0%, #124A9C 100%);
    border-radius: 26px;
    padding: 26px 28px;
    margin-bottom: 24px;
    box-shadow: 0 24px 60px rgba(6, 32, 63, 0.18);
    color: #ffffff;
    overflow: hidden;
    position: relative;
}



body.colmena-client-page .colmena-resident-main {
    display: flex;
    align-items: center;
    gap: 18px;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-resident-icon {
    width: 62px;
    height: 62px;
    border-radius: 20px;
    background: rgba(255,255,255,0.14);
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

body.colmena-client-page .colmena-resident-icon i {
    color: #ffffff;
    font-size: 26px;
}

body.colmena-client-page .colmena-resident-info {
    min-width: 0;
}

body.colmena-client-page .colmena-resident-label {
    display: inline-flex;
    margin-bottom: 7px;
    color: rgba(255,255,255,0.70);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

body.colmena-client-page .colmena-resident-info h2 {
    margin: 0;
    color: #ffffff;
    font-size: 27px;
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: -0.03em;
}

body.colmena-client-page .colmena-resident-info p {
    margin: 8px 0 0;
    color: rgba(255,255,255,0.82);
    font-size: 14px;
    line-height: 1.6;
}

body.colmena-client-page .colmena-resident-info p span {
    display: inline-block;
    margin-left: 10px;
    padding-left: 10px;
    border-left: 1px solid rgba(255,255,255,0.25);
}

body.colmena-client-page .colmena-resident-status {
    display: flex;
    align-items: center;
    gap: 14px;
    position: relative;
    z-index: 2;
    flex: 0 0 auto;
}

body.colmena-client-page .colmena-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
}

body.colmena-client-page .colmena-status-pending {
    background: #FFF7E6;
    color: #C2410C;
}

body.colmena-client-page .colmena-status-ok {
    background: #ECFDF5;
    color: #047857;
}

body.colmena-client-page .colmena-resident-actions {
    display: flex;
    gap: 10px;
}

body.colmena-client-page .colmena-resident-actions .btn {
    min-height: 40px;
    border-radius: 12px !important;
    padding: 9px 14px;
    font-weight: 800;
}

body.colmena-client-page .colmena-resident-actions .colmena-btn-primary {
    background: #ffffff !important;
    border-color: #ffffff !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-resident-actions .colmena-btn-light {
    background: rgba(255,255,255,0.12) !important;
    border: 1px solid rgba(255,255,255,0.28) !important;
    color: #ffffff !important;
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-resident-card {
        align-items: flex-start;
        flex-direction: column;
        padding: 24px;
    }

    body.colmena-client-page .colmena-resident-status {
        width: 100%;
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-resident-actions {
        width: 100%;
    }

    body.colmena-client-page .colmena-resident-actions .btn {
        width: 100%;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-resident-main {
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-resident-info h2 {
        font-size: 23px;
    }

    body.colmena-client-page .colmena-resident-info p span {
        display: block;
        margin-left: 0;
        padding-left: 0;
        border-left: 0;
        margin-top: 4px;
    }

    body.colmena-client-page .colmena-resident-actions {
        flex-direction: column;
    }
}

/* ==========================================================
   Colmena - Ocultar Powered by WHMCS en portal residente
   ========================================================== */

body.colmena-client-page .primary-content > p[style="text-align:center;"],
body.colmena-client-page .primary-content > p[style*="text-align:center"],
body.colmena-client-page p:has(a[href*="whmcs.com"]) {
    display: none !important;
}


/* ==========================================================
   Colmena - Menú superior residente
   ========================================================== */

body.colmena-client-page .colmena-user-menu {
    position: relative;
}

body.colmena-client-page .colmena-user-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 12px;
    border: 0;
    background: transparent;
    color: #0F172A;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
}

body.colmena-client-page .colmena-user-button i {
    color: #124A9C;
    font-size: 17px;
}

body.colmena-client-page .colmena-user-dropdown {
    width: 280px;
    padding: 0;
    border: 1px solid #E6ECF3;
    border-radius: 18px;
    box-shadow: 0 22px 55px rgba(15, 23, 42, 0.14);
    overflow: hidden;
    margin-top: 8px !important;
}

body.colmena-client-page .colmena-user-dropdown-header {
    padding: 18px;
    background: #F8FAFC;
    border-bottom: 1px solid #E6ECF3;
}

body.colmena-client-page .colmena-user-dropdown-header strong {
    display: block;
    color: #0F172A;
    font-size: 15px;
    font-weight: 800;
}

body.colmena-client-page .colmena-user-dropdown-header span {
    display: block;
    margin-top: 4px;
    color: #64748B;
    font-size: 13px;
    font-weight: 600;
}

body.colmena-client-page .colmena-user-dropdown-header small {
    display: block;
    margin-top: 3px;
    color: #124A9C;
    font-size: 12px;
    font-weight: 700;
}

body.colmena-client-page .colmena-user-dropdown .dropdown-item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 13px 18px;
    color: #334155;
    font-size: 13px;
    font-weight: 700;
}

body.colmena-client-page .colmena-user-dropdown .dropdown-item i {
    width: 18px;
    color: #94A3B8;
    text-align: center;
}

body.colmena-client-page .colmena-user-dropdown .dropdown-item:hover {
    background: rgba(18, 74, 156, 0.08);
    color: #06203F;
}

body.colmena-client-page .colmena-user-dropdown .dropdown-divider {
    margin: 0;
    border-top: 1px solid #E6ECF3;
}

body.colmena-client-page .colmena-user-dropdown .colmena-dropdown-logout {
    color: #B91C1C;
}

body.colmena-client-page .colmena-user-dropdown .colmena-dropdown-logout i {
    color: #B91C1C;
}

body.colmena-client-page .colmena-user-button:focus,
body.colmena-client-page .colmena-user-button:active {
    outline: none !important;
    box-shadow: none !important;
}


/* ==========================================================
   Colmena - Light SaaS layout inspirado en dashboard premium
   ========================================================== */

body.colmena-client-page {
    background: #F4F7FB !important;
    color: #0F172A !important;
}

body.colmena-client-page .colmena-app-topbar {
    left: 248px;
    height: 72px;
    background: rgba(255,255,255,0.96);
    border-bottom: 1px solid #E6ECF3;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.035);
    padding: 0 34px;
    gap: 24px;
}

body.colmena-client-page .colmena-app-topbar-title {
    flex: 0 0 auto;
}

body.colmena-client-page .colmena-app-topbar-title span {
    color: #64748B;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

body.colmena-client-page .colmena-top-main-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex: 1 1 auto;
}

body.colmena-client-page .colmena-top-main-nav-item {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 12px;
    color: #475569 !important;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-top-main-nav-item:hover {
    background: rgba(18, 74, 156, 0.08);
    color: #06203F !important;
}

body.colmena-client-page .colmena-top-main-nav-item.active {
    background: rgba(18, 74, 156, 0.12);
    color: #124A9C !important;
}

body.colmena-client-page .colmena-app-topbar-actions {
    flex: 0 0 auto;
    gap: 14px;
}

body.colmena-client-page .colmena-app-topbar-actions > a {
    color: #334155 !important;
    font-size: 13px;
    font-weight: 800;
}

body.colmena-client-page .colmena-user-button {
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid #D8E0EA;
    border-radius: 12px;
    background: #FFFFFF;
    color: #0F172A;
}

body.colmena-client-page .colmena-user-button:hover {
    background: #F8FAFC;
    border-color: #C7D2E1;
}

body.colmena-client-page .colmena-user-button:focus,
body.colmena-client-page .colmena-user-button:active {
    outline: none !important;
    box-shadow: none !important;
}

body.colmena-client-page .colmena-app-sidebar {
    background: #FFFFFF;
    border-right: 1px solid #E6ECF3;
    box-shadow: 14px 0 40px rgba(15, 23, 42, 0.04);
}

body.colmena-client-page .colmena-app-nav {
    padding: 24px 14px;
}

body.colmena-client-page .colmena-app-nav-item {
    color: #334155;
    font-size: 14px;
    font-weight: 800;
}

body.colmena-client-page .colmena-app-nav-item:first-child {
    background: rgba(18, 74, 156, 0.12);
    color: #06203F;
}

body.colmena-client-page .colmena-app-nav-item:hover {
    background: rgba(18, 74, 156, 0.08);
}

body.colmena-client-page section#main-body {
    background: #F4F7FB !important;
    padding-top: 112px !important;
}

body.colmena-client-page .colmena-client-dashboard {
    max-width: 1180px;
}

body.colmena-client-page .colmena-dashboard-heading {
    margin-bottom: 22px;
}

body.colmena-client-page .colmena-dashboard-heading h1 {
    color: #0F172A;
    font-size: 34px;
    font-weight: 900;
    letter-spacing: -0.04em;
}

body.colmena-client-page .colmena-dashboard-heading p {
    color: #64748B;
}

body.colmena-client-page .colmena-resident-card {
    background: #FFFFFF;
    color: #0F172A;
    border: 1px solid #E6ECF3;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

body.colmena-client-page .colmena-resident-card:after {
    background: rgba(18, 74, 156, 0.06);
}

body.colmena-client-page .colmena-resident-icon {
    background: rgba(18, 74, 156, 0.10);
}

body.colmena-client-page .colmena-resident-icon i {
    color: #124A9C;
}

body.colmena-client-page .colmena-resident-label {
    color: #64748B;
}

body.colmena-client-page .colmena-resident-info h2 {
    color: #0F172A;
}

body.colmena-client-page .colmena-resident-info p {
    color: #64748B;
}

body.colmena-client-page .colmena-resident-info p span {
    border-left: 1px solid #D8E0EA;
}

body.colmena-client-page .colmena-resident-actions .colmena-btn-light {
    background: #FFFFFF !important;
    border: 1px solid #D8E0EA !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-summary-card,
body.colmena-client-page .colmena-panel {
    background: #FFFFFF !important;
    border: 1px solid #E6ECF3 !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.055) !important;
}

body.colmena-client-page .colmena-summary-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08) !important;
}

body.colmena-client-page .colmena-summary-number {
    color: #06203F;
}

body.colmena-client-page .colmena-summary-label {
    color: #64748B;
}

body.colmena-client-page .colmena-panel-header {
    background: #FFFFFF !important;
    border-bottom: 1px solid #E6ECF3 !important;
}

body.colmena-client-page .colmena-panel-body {
    color: #334155;
}

@media (max-width: 1199px) {
    body.colmena-client-page .colmena-top-main-nav {
        display: none;
    }
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-app-topbar {
        left: 0;
        padding: 0 18px;
    }

    body.colmena-client-page .colmena-app-topbar-title {
        display: none;
    }

    body.colmena-client-page .colmena-app-topbar-actions {
        width: 100%;
        justify-content: flex-end;
    }
}

/* ==========================================================
   Colmena - Refinamiento visual dashboard residente claro
   ========================================================== */

body.colmena-client-page .colmena-resident-card {
    min-height: 128px;
    padding: 24px 28px;
}

body.colmena-client-page .colmena-resident-info h2 {
    font-size: 25px;
}

body.colmena-client-page .colmena-summary-card {
    min-height: 138px !important;
}

body.colmena-client-page .colmena-summary-number {
    font-size: 38px;
    margin-top: 30px;
}

body.colmena-client-page .colmena-panel {
    border-radius: 20px !important;
}

body.colmena-client-page .colmena-panel-title {
    font-size: 15px !important;
}

body.colmena-client-page .colmena-panel-btn,
body.colmena-client-page .colmena-panel-header .btn {
    font-size: 11px !important;
    padding: 5px 10px !important;
    min-height: auto !important;
}

body.colmena-client-page .colmena-panel-body {
    font-size: 14px;
    line-height: 1.6;
}

body.colmena-client-page .colmena-status-pending {
    background: #FFF7E6;
    color: #C2410C;
    border: 1px solid #FED7AA;
}

body.colmena-client-page .colmena-alert-warning {
    background: linear-gradient(90deg, #FFF7E6 0%, #FFFDF6 100%);
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-app-topbar-actions > a {
        display: none !important;
    }

    body.colmena-client-page .colmena-app-topbar-actions {
        justify-content: flex-end !important;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-alert {
        align-items: flex-start !important;
        flex-wrap: wrap !important;
    }

    body.colmena-client-page .colmena-alert-content {
        flex: 1 1 calc(100% - 52px) !important;
    }

    body.colmena-client-page .colmena-alert-link {
        margin-left: 52px !important;
        margin-top: 4px !important;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-panel .badge,
    body.colmena-client-page .colmena-panel .label {
        max-width: none !important;
        white-space: nowrap !important;
        font-size: 10px !important;
        padding: 5px 8px !important;
    }
}

/* ==========================================================
   Colmena - Menú hamburguesa mobile
   ========================================================== */

body.colmena-client-page .colmena-mobile-topbar-brand {
    display: none;
}

body.colmena-client-page .colmena-mobile-sidebar-close {
    display: none;
}

body.colmena-client-page .colmena-sidebar-overlay {
    display: none;
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-app-topbar {
        height: 72px;
        left: 0 !important;
        padding: 0 16px !important;
        justify-content: space-between;
    }

    body.colmena-client-page .colmena-mobile-topbar-brand {
        display: flex;
        align-items: center;
        gap: 12px;
        flex: 0 0 auto;
    }

    body.colmena-client-page .colmena-mobile-menu-toggle {
        width: 42px;
        height: 42px;
        border: 1px solid #D8E0EA;
        border-radius: 12px;
        background: #ffffff;
        color: #06203F;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 17px;
        cursor: pointer;
    }

    body.colmena-client-page .colmena-mobile-menu-toggle:focus,
    body.colmena-client-page .colmena-mobile-menu-toggle:active {
        outline: none !important;
        box-shadow: none !important;
    }

    body.colmena-client-page .colmena-mobile-logo {
        display: inline-flex;
        align-items: center;
        text-decoration: none !important;
    }

    body.colmena-client-page .colmena-mobile-logo img {
        width: 132px;
        height: auto;
        display: block;
    }

    body.colmena-client-page .colmena-app-topbar-title {
        display: none !important;
    }

    body.colmena-client-page .colmena-app-topbar-actions {
        width: auto !important;
        flex: 0 0 auto;
        justify-content: flex-end !important;
        gap: 10px !important;
    }

    body.colmena-client-page .colmena-app-topbar-actions > a {
        display: none !important;
    }

    body.colmena-client-page .colmena-app-sidebar {
        transform: translateX(-100%);
        transition: transform .22s ease;
        z-index: 1200;
    }

    body.colmena-client-page.colmena-menu-open .colmena-app-sidebar {
        transform: translateX(0);
    }

    body.colmena-client-page .colmena-sidebar-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.42);
        opacity: 0;
        pointer-events: none;
        transition: opacity .22s ease;
        z-index: 1190;
    }

    body.colmena-client-page.colmena-menu-open .colmena-sidebar-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    body.colmena-client-page .colmena-app-logo {
        justify-content: space-between;
        gap: 12px;
    }

    body.colmena-client-page .colmena-mobile-sidebar-close {
        display: inline-flex;
        width: 38px;
        height: 38px;
        border: 1px solid #D8E0EA;
        border-radius: 12px;
        background: #ffffff;
        color: #06203F;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }

    body.colmena-client-page .colmena-mobile-sidebar-close:focus,
    body.colmena-client-page .colmena-mobile-sidebar-close:active {
        outline: none !important;
        box-shadow: none !important;
    }

    body.colmena-client-page section#main-body {
        margin-left: 0 !important;
        padding-top: 96px !important;
    }
}

@media (max-width: 420px) {
    body.colmena-client-page .colmena-mobile-logo img {
        width: 120px;
    }

    body.colmena-client-page .colmena-user-button {
        max-width: 150px;
    }

    body.colmena-client-page .colmena-user-button span {
        max-width: 92px;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }
}

/* ==========================================================
   Colmena - Limpieza tarjeta residente modo claro
   ========================================================== */

body.colmena-client-page .colmena-resident-card:after {
    display: none !important;
}

body.colmena-client-page .colmena-resident-card {
    overflow: visible !important;
}

/* ==========================================================
   Colmena - Estado activo real en navegación
   ========================================================== */

body.colmena-client-page .colmena-app-nav-item:first-child {
    background: transparent;
    color: #334155;
}

body.colmena-client-page .colmena-app-nav-item:first-child i {
    color: #124A9C;
}

body.colmena-client-page .colmena-app-nav-item.active,
body.colmena-client-page .colmena-app-nav-item.active:first-child {
    background: rgba(18, 74, 156, 0.12) !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-app-nav-item.active i,
body.colmena-client-page .colmena-app-nav-item.active:first-child i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-top-main-nav-item.active {
    background: rgba(18, 74, 156, 0.12) !important;
    color: #124A9C !important;
}

/* ==========================================================
   Colmena - Portal residente v2 premium light polish
   Pegar al final de colmena.css
   ========================================================== */

body.colmena-client-page {
    background:
        radial-gradient(circle at 18% 8%, rgba(18, 74, 156, 0.08) 0, rgba(18, 74, 156, 0) 28%),
        radial-gradient(circle at 85% 20%, rgba(245, 180, 0, 0.10) 0, rgba(245, 180, 0, 0) 24%),
        #F4F7FB !important;
}

/* Contenedor general */
body.colmena-client-page .colmena-client-dashboard {
    max-width: 1160px !important;
    margin: 0 auto !important;
}

/* Topbar más limpia */
body.colmena-client-page .colmena-app-topbar {
    height: 76px !important;
    background: rgba(255,255,255,0.94) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(226, 232, 240, 0.85) !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.045) !important;
}

body.colmena-client-page .colmena-top-main-nav-item {
    min-height: 38px !important;
    padding: 0 15px !important;
    border-radius: 999px !important;
    color: #475569 !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-top-main-nav-item:hover {
    background: #EEF5FF !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-top-main-nav-item.active {
    background: #E7F0FF !important;
    color: #124A9C !important;
    box-shadow: inset 0 0 0 1px rgba(18, 74, 156, 0.08);
}

/* Sidebar más SaaS */
body.colmena-client-page .colmena-app-sidebar {
    width: 248px !important;
    background: #FFFFFF !important;
    border-right: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 18px 0 45px rgba(15, 23, 42, 0.045) !important;
}

body.colmena-client-page .colmena-app-logo {
    height: 94px !important;
    padding: 0 26px !important;
}

body.colmena-client-page .colmena-app-nav {
    padding: 22px 14px !important;
    gap: 7px !important;
}

body.colmena-client-page .colmena-app-nav-item {
    position: relative;
    min-height: 46px !important;
    border-radius: 15px !important;
    color: #334155 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-app-nav-item i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-app-nav-item:hover {
    background: #F1F6FF !important;
    color: #06203F !important;
    transform: translateX(2px);
}

body.colmena-client-page .colmena-app-nav-item.active {
    background: linear-gradient(135deg, #EAF2FF 0%, #F7FAFF 100%) !important;
    color: #06203F !important;
    box-shadow: inset 0 0 0 1px rgba(18, 74, 156, 0.08);
}

body.colmena-client-page .colmena-app-nav-item.active:before {
    content: "";
    position: absolute;
    left: -14px;
    top: 10px;
    width: 4px;
    height: 26px;
    border-radius: 999px;
    background: #124A9C;
}

/* Header principal */
body.colmena-client-page .colmena-dashboard-heading {
    align-items: center !important;
    margin-bottom: 24px !important;
}

body.colmena-client-page .colmena-dashboard-kicker {
    background: #EAF2FF !important;
    color: #124A9C !important;
    border: 1px solid rgba(18, 74, 156, 0.08);
    box-shadow: 0 8px 18px rgba(18, 74, 156, 0.06);
}

body.colmena-client-page .colmena-dashboard-heading h1 {
    font-size: 36px !important;
    color: #0F172A !important;
    letter-spacing: -0.045em !important;
}

body.colmena-client-page .colmena-dashboard-heading p {
    max-width: 620px;
    color: #64748B !important;
    font-size: 15px !important;
    line-height: 1.65;
}

/* Botones superiores */
body.colmena-client-page .colmena-dashboard-actions .btn {
    min-height: 46px !important;
    padding: 11px 18px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}

body.colmena-client-page .colmena-dashboard-actions .colmena-btn-primary {
    background: #06203F !important;
    border-color: #06203F !important;
    box-shadow: 0 14px 28px rgba(6, 32, 63, 0.18);
}

body.colmena-client-page .colmena-dashboard-actions .colmena-btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(6, 32, 63, 0.22);
}

body.colmena-client-page .colmena-dashboard-actions .colmena-btn-light {
    background: #FFFFFF !important;
    border-color: #D8E0EA !important;
    color: #06203F !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.045);
}

body.colmena-client-page .colmena-dashboard-actions .colmena-btn-light:hover {
    background: #F8FAFC !important;
    transform: translateY(-1px);
}

/* Tarjeta del residente */
body.colmena-client-page .colmena-resident-card {
    position: relative;
    min-height: 142px !important;
    padding: 28px 30px !important;
    border-radius: 28px !important;
    background:
        radial-gradient(circle at 94% 18%, rgba(245, 180, 0, 0.18) 0, rgba(245, 180, 0, 0) 28%),
        radial-gradient(circle at 8% 0%, rgba(18, 74, 156, 0.11) 0, rgba(18, 74, 156, 0) 30%),
        #FFFFFF !important;
    border: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.075) !important;
    overflow: hidden !important;
}

body.colmena-client-page .colmena-resident-card:before {
    content: "";
    position: absolute;
    left: 0;
    top: 22px;
    bottom: 22px;
    width: 5px;
    border-radius: 0 999px 999px 0;
    background: #124A9C;
}

body.colmena-client-page .colmena-resident-icon {
    width: 66px !important;
    height: 66px !important;
    border-radius: 22px !important;
    background: linear-gradient(135deg, #EAF2FF 0%, #F8FBFF 100%) !important;
    border: 1px solid rgba(18, 74, 156, 0.09);
    box-shadow: 0 14px 30px rgba(18, 74, 156, 0.10);
}

body.colmena-client-page .colmena-resident-icon i {
    color: #124A9C !important;
    font-size: 27px !important;
}

body.colmena-client-page .colmena-resident-label {
    color: #64748B !important;
    font-size: 11px !important;
    letter-spacing: 0.08em !important;
}

body.colmena-client-page .colmena-resident-info h2 {
    color: #0F172A !important;
    font-size: 27px !important;
    font-weight: 900 !important;
}

body.colmena-client-page .colmena-resident-info p {
    color: #64748B !important;
    font-size: 14px !important;
}

body.colmena-client-page .colmena-resident-info p span {
    border-left-color: #D8E0EA !important;
}

/* Estado */
body.colmena-client-page .colmena-status-badge {
    min-height: 40px !important;
    padding: 0 15px !important;
    font-size: 12px !important;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.045);
}

body.colmena-client-page .colmena-status-pending {
    background: #FFF7E6 !important;
    border: 1px solid #FED7AA !important;
    color: #C2410C !important;
}

body.colmena-client-page .colmena-status-ok {
    background: #ECFDF5 !important;
    border: 1px solid #BBF7D0 !important;
    color: #047857 !important;
}

body.colmena-client-page .colmena-resident-actions .btn {
    min-height: 42px !important;
    padding: 10px 16px !important;
    border-radius: 13px !important;
    font-size: 13px !important;
}

/* Alerta de facturas */
body.colmena-client-page .colmena-alert {
    border-radius: 22px !important;
    padding: 17px 20px !important;
    margin-bottom: 24px !important;
    box-shadow: 0 18px 42px rgba(245, 158, 11, 0.08);
}

body.colmena-client-page .colmena-alert-warning {
    background:
        linear-gradient(90deg, #FFF7E6 0%, #FFFDF6 100%) !important;
    border: 1px solid #FED7AA !important;
}

body.colmena-client-page .colmena-alert-icon {
    width: 40px !important;
    height: 40px !important;
    background: #FFEDD5 !important;
    color: #EA580C !important;
}

body.colmena-client-page .colmena-alert-content strong {
    color: #9A3412 !important;
    font-weight: 900 !important;
}

body.colmena-client-page .colmena-alert-content span {
    color: #9A3412 !important;
}

body.colmena-client-page .colmena-alert-link {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    padding: 0 14px;
    border-radius: 999px;
    background: #FFFFFF;
    border: 1px solid #FED7AA;
    color: #EA580C !important;
    font-size: 13px;
    font-weight: 900 !important;
}

/* Cards de resumen */
body.colmena-client-page .colmena-summary-grid {
    gap: 18px !important;
    margin-bottom: 26px !important;
}

body.colmena-client-page .colmena-summary-card {
    min-height: 148px !important;
    padding: 22px !important;
    border-radius: 24px !important;
    background:
        linear-gradient(180deg, #FFFFFF 0%, #FAFCFF 100%) !important;
    border: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.065) !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-summary-card:before {
    content: "";
    position: absolute;
    left: 22px;
    top: 18px;
    width: 38px;
    height: 5px;
    border-radius: 999px;
    background: #EAF2FF;
}

body.colmena-client-page .colmena-summary-card:hover {
    transform: translateY(-3px) !important;
    border-color: rgba(18, 74, 156, 0.20) !important;
    box-shadow: 0 28px 65px rgba(15, 23, 42, 0.09) !important;
}

body.colmena-client-page .colmena-summary-icon {
    right: 22px !important;
    top: 22px !important;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: #F1F6FF;
    color: #A7B8D2 !important;
    font-size: 24px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.colmena-client-page .colmena-summary-number {
    margin-top: 38px !important;
    color: #06203F !important;
    font-size: 40px !important;
    font-weight: 900 !important;
    letter-spacing: -0.045em;
}

body.colmena-client-page .colmena-summary-label {
    margin-top: 10px !important;
    color: #475569 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
}

/* Paneles inferiores */
body.colmena-client-page .colmena-panel-grid {
    gap: 22px !important;
}

body.colmena-client-page .colmena-panel {
    border-radius: 24px !important;
    border: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 0 22px 52px rgba(15, 23, 42, 0.065) !important;
    background: #FFFFFF !important;
}

body.colmena-client-page .colmena-panel-header {
    min-height: 58px;
    padding: 16px 18px !important;
    background: linear-gradient(180deg, #FFFFFF 0%, #FBFDFF 100%) !important;
}

body.colmena-client-page .colmena-panel-title {
    display: flex;
    align-items: center;
    gap: 7px;
    color: #06203F !important;
    font-size: 15px !important;
    font-weight: 900 !important;
}

body.colmena-client-page .colmena-panel-title i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-panel-body {
    padding: 18px 20px !important;
    color: #334155 !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
}

body.colmena-client-page .colmena-panel-list .list-group-item {
    padding: 15px 20px !important;
    border-color: #EEF2F7 !important;
    color: #334155 !important;
}

body.colmena-client-page .colmena-panel-list .list-group-item:hover {
    background: #F8FAFC !important;
}

body.colmena-client-page .colmena-panel-footer {
    padding: 14px 20px !important;
    background: #F8FAFC !important;
}

body.colmena-client-page .colmena-panel-btn,
body.colmena-client-page .colmena-panel-header .btn {
    border-radius: 999px !important;
    font-weight: 900 !important;
    box-shadow: none !important;
}

/* Botones pequeños por color de WHMCS */
body.colmena-client-page .colmena-panel-header .btn,
body.colmena-client-page .colmena-panel-btn {
    background: #F5B400 !important;
    border-color: #F5B400 !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-panel-header .btn:hover,
body.colmena-client-page .colmena-panel-btn:hover {
    filter: brightness(0.97);
}

/* Badges internos */
body.colmena-client-page .badge,
body.colmena-client-page .label {
    border-radius: 999px !important;
    font-weight: 900 !important;
}

/* Mejorar textos de servicios dentro de panel */
body.colmena-client-page .colmena-panel-list a[href*="clientarea.php?action=productdetails"],
body.colmena-client-page .colmena-panel-list a[href*="clientarea.php?action=services"] {
    font-weight: 700;
}

/* Menú de usuario */
body.colmena-client-page .colmena-user-button {
    border-radius: 999px !important;
    border-color: #D8E0EA !important;
    background: #FFFFFF !important;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.045);
}

body.colmena-client-page .colmena-user-button:hover {
    background: #F8FAFC !important;
    border-color: #BFD0E4 !important;
}

body.colmena-client-page .colmena-user-dropdown {
    border-radius: 20px !important;
    box-shadow: 0 26px 70px rgba(15, 23, 42, 0.16) !important;
}

/* Responsive */
@media (max-width: 1199px) {
    body.colmena-client-page .colmena-client-dashboard {
        max-width: 100% !important;
    }
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-dashboard-heading {
        align-items: flex-start !important;
    }

    body.colmena-client-page .colmena-dashboard-actions {
        width: 100%;
    }

    body.colmena-client-page .colmena-dashboard-actions .btn {
        flex: 1 1 auto;
        justify-content: center;
    }

    body.colmena-client-page .colmena-resident-card {
        padding: 24px !important;
    }

    body.colmena-client-page .colmena-resident-status {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    body.colmena-client-page .colmena-resident-actions {
        width: auto !important;
    }

    body.colmena-client-page .colmena-resident-actions .btn {
        width: auto !important;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page section#main-body {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    body.colmena-client-page .colmena-dashboard-heading h1 {
        font-size: 31px !important;
    }

    body.colmena-client-page .colmena-dashboard-actions {
        flex-direction: column;
    }

    body.colmena-client-page .colmena-resident-card {
        border-radius: 24px !important;
    }

    body.colmena-client-page .colmena-resident-status {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    body.colmena-client-page .colmena-resident-actions {
        width: 100% !important;
    }

    body.colmena-client-page .colmena-resident-actions .btn {
        width: 100% !important;
    }

    body.colmena-client-page .colmena-summary-card {
        min-height: 132px !important;
    }

    body.colmena-client-page .colmena-summary-number {
        font-size: 36px !important;
    }
}


/* ==========================================================
   Colmena - Portal residente v3 SaaS premium
   ========================================================== */

body.colmena-client-page {
    background:
        radial-gradient(circle at 14% 8%, rgba(18, 74, 156, 0.10) 0, rgba(18, 74, 156, 0) 30%),
        radial-gradient(circle at 92% 18%, rgba(245, 180, 0, 0.16) 0, rgba(245, 180, 0, 0) 26%),
        linear-gradient(180deg, #F8FAFD 0%, #EFF4FA 100%) !important;
    color: #0F172A !important;
}

body.colmena-client-page section#main-body {
    background: transparent !important;
    padding-top: 112px !important;
    padding-bottom: 64px !important;
}

body.colmena-client-page section#main-body > .container {
    max-width: 1280px !important;
}

body.colmena-client-page .colmena-client-dashboard-v3 {
    max-width: 1180px !important;
    margin: 0 auto !important;
}

/* Topbar */
body.colmena-client-page .colmena-app-topbar {
    height: 76px !important;
    background: rgba(255, 255, 255, 0.86) !important;
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(226, 232, 240, 0.85) !important;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.055) !important;
}

body.colmena-client-page .colmena-top-main-nav-item {
    min-height: 38px !important;
    padding: 0 15px !important;
    border-radius: 999px !important;
    color: #475569 !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-top-main-nav-item:hover {
    background: #EEF5FF !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-top-main-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 12px 24px rgba(6, 32, 63, 0.18);
}

/* Sidebar */
body.colmena-client-page .colmena-app-sidebar {
    background: rgba(255, 255, 255, 0.96) !important;
    border-right: 1px solid rgba(226, 232, 240, 0.95) !important;
    box-shadow: 18px 0 45px rgba(15, 23, 42, 0.045) !important;
}

body.colmena-client-page .colmena-app-logo {
    height: 94px !important;
    padding: 0 26px !important;
}

body.colmena-client-page .colmena-app-nav {
    padding: 22px 14px !important;
    gap: 7px !important;
}

body.colmena-client-page .colmena-app-nav-item:first-child {
    background: transparent !important;
    color: #334155 !important;
}

body.colmena-client-page .colmena-app-nav-item {
    position: relative;
    min-height: 48px !important;
    border-radius: 16px !important;
    color: #334155 !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-app-nav-item i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-app-nav-item:hover {
    background: #F1F6FF !important;
    color: #06203F !important;
    transform: translateX(2px);
}

body.colmena-client-page .colmena-app-nav-item.active,
body.colmena-client-page .colmena-app-nav-item.active:first-child {
    background: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 14px 28px rgba(6, 32, 63, 0.18);
}

body.colmena-client-page .colmena-app-nav-item.active i,
body.colmena-client-page .colmena-app-nav-item.active:first-child i {
    color: #FFFFFF !important;
}

body.colmena-client-page .colmena-app-nav-item.active:before {
    content: "";
    position: absolute;
    left: -14px;
    top: 11px;
    width: 4px;
    height: 26px;
    border-radius: 999px;
    background: #F5B400;
}

/* Hero superior */
body.colmena-client-page .colmena-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 22px;
    margin-bottom: 22px;
}

body.colmena-client-page .colmena-hero-main {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
}

body.colmena-client-page .colmena-dashboard-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 13px;
    margin-bottom: 12px;
    border-radius: 999px;
    background: #EAF2FF !important;
    color: #124A9C !important;
    border: 1px solid rgba(18, 74, 156, 0.08);
    box-shadow: 0 8px 18px rgba(18, 74, 156, 0.06);
    font-size: 12px;
    font-weight: 850;
}

body.colmena-client-page .colmena-hero-copy h1 {
    margin: 0;
    color: #0F172A !important;
    font-size: 38px !important;
    line-height: 1.05;
    font-weight: 950 !important;
    letter-spacing: -0.055em;
}

body.colmena-client-page .colmena-hero-copy p {
    margin: 12px 0 0;
    max-width: 640px;
    color: #64748B;
    font-size: 15px;
    line-height: 1.7;
}

body.colmena-client-page .colmena-hero-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
}

body.colmena-client-page .colmena-hero-actions .btn,
body.colmena-client-page .colmena-btn-primary,
body.colmena-client-page .colmena-btn-light {
    min-height: 46px !important;
    padding: 11px 18px !important;
    border-radius: 15px !important;
    font-size: 14px !important;
    font-weight: 900 !important;
}

body.colmena-client-page .colmena-btn-primary {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 16px 34px rgba(6, 32, 63, 0.22);
}

body.colmena-client-page .colmena-btn-primary:hover {
    background: #0B2E59 !important;
    border-color: #0B2E59 !important;
    transform: translateY(-1px);
}

body.colmena-client-page .colmena-btn-light {
    background: rgba(255,255,255,0.92) !important;
    border: 1px solid #D8E0EA !important;
    color: #06203F !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.055);
}

body.colmena-client-page .colmena-btn-light:hover {
    background: #FFFFFF !important;
    border-color: #BFD0E4 !important;
    transform: translateY(-1px);
}

/* Tarjeta residente */
body.colmena-client-page .colmena-resident-card-v3 {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 150px !important;
    padding: 30px 32px !important;
    border-radius: 30px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.92) 54%, rgba(255,247,230,0.92) 100%) !important;
    border: 1px solid rgba(226, 232, 240, 0.90) !important;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.085) !important;
    overflow: hidden !important;
}

body.colmena-client-page .colmena-resident-card-v3:before {
    content: "";
    position: absolute;
    left: 0;
    top: 24px;
    bottom: 24px;
    width: 5px;
    border-radius: 0 999px 999px 0;
    background: #124A9C;
}

body.colmena-client-page .colmena-resident-card-v3:after {
    content: "";
    position: absolute;
    right: -80px;
    top: -100px;
    width: 280px;
    height: 280px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(245,180,0,0.24) 0, rgba(245,180,0,0) 68%);
    display: block !important;
    pointer-events: none;
}

body.colmena-client-page .colmena-resident-main {
    display: flex;
    align-items: center;
    gap: 18px;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-resident-icon {
    width: 68px !important;
    height: 68px !important;
    border-radius: 23px !important;
    background: linear-gradient(135deg, #EAF2FF 0%, #FFFFFF 100%) !important;
    border: 1px solid rgba(18, 74, 156, 0.10);
    box-shadow: 0 16px 34px rgba(18, 74, 156, 0.12);
}

body.colmena-client-page .colmena-resident-icon i {
    color: #124A9C !important;
    font-size: 28px !important;
}

body.colmena-client-page .colmena-resident-label {
    margin-bottom: 7px;
    color: #64748B !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    text-transform: uppercase;
    letter-spacing: 0.085em;
}

body.colmena-client-page .colmena-resident-info h2 {
    margin: 0;
    color: #0F172A !important;
    font-size: 28px !important;
    line-height: 1.15;
    font-weight: 950 !important;
    letter-spacing: -0.045em;
}

body.colmena-client-page .colmena-resident-info p {
    margin: 9px 0 0;
    color: #64748B !important;
    font-size: 14px;
    line-height: 1.6;
}

body.colmena-client-page .colmena-resident-info p span {
    display: inline-block;
    margin-left: 10px;
    padding-left: 10px;
    border-left: 1px solid #D8E0EA !important;
}

body.colmena-client-page .colmena-resident-info p span:first-child {
    margin-left: 0;
    padding-left: 0;
    border-left: 0 !important;
}

body.colmena-client-page .colmena-resident-status {
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-status-badge {
    min-height: 40px !important;
    padding: 0 15px !important;
    border-radius: 999px;
    font-size: 12px !important;
    font-weight: 900 !important;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

body.colmena-client-page .colmena-status-pending {
    background: #FFF7E6 !important;
    border: 1px solid #FED7AA !important;
    color: #C2410C !important;
}

body.colmena-client-page .colmena-status-ok {
    background: #ECFDF5 !important;
    border: 1px solid #BBF7D0 !important;
    color: #047857 !important;
}

/* Alerta */
body.colmena-client-page .colmena-payment-alert-v3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    margin-bottom: 22px;
    border-radius: 24px;
    background: linear-gradient(90deg, #FFF7E6 0%, #FFFDF6 100%);
    border: 1px solid #FED7AA;
    box-shadow: 0 20px 44px rgba(245, 158, 11, 0.10);
}

body.colmena-client-page .colmena-payment-alert-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

body.colmena-client-page .colmena-alert-icon {
    width: 42px !important;
    height: 42px !important;
    border-radius: 999px;
    background: #FFEDD5 !important;
    color: #EA580C !important;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

body.colmena-client-page .colmena-payment-alert-v3 strong {
    display: block;
    color: #9A3412;
    font-size: 14px;
    font-weight: 950;
}

body.colmena-client-page .colmena-payment-alert-v3 span {
    display: block;
    margin-top: 4px;
    color: #9A3412;
    font-size: 13px;
}

body.colmena-client-page .colmena-alert-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: #FFFFFF;
    border: 1px solid #FED7AA;
    color: #EA580C !important;
    font-size: 13px;
    font-weight: 950 !important;
    text-decoration: none !important;
    white-space: nowrap;
}

/* Summary cards */
body.colmena-client-page .colmena-summary-grid-v3 {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px !important;
    margin-bottom: 24px !important;
}

body.colmena-client-page .colmena-summary-card-v3 {
    position: relative;
    display: flex !important;
    flex-direction: column;
    min-height: 172px !important;
    padding: 20px !important;
    border-radius: 26px !important;
    background: rgba(255,255,255,0.92) !important;
    border: 1px solid rgba(226, 232, 240, 0.92) !important;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.070) !important;
    text-decoration: none !important;
    overflow: hidden;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-summary-card-v3:hover {
    transform: translateY(-4px) !important;
    border-color: rgba(18, 74, 156, 0.24) !important;
    box-shadow: 0 32px 72px rgba(15, 23, 42, 0.10) !important;
}

body.colmena-client-page .colmena-summary-card-v3:before {
    content: "";
    position: absolute;
    right: -42px;
    top: -42px;
    width: 120px;
    height: 120px;
    border-radius: 999px;
    background: rgba(18, 74, 156, 0.06);
}

body.colmena-client-page .colmena-summary-card-v3.colmena-summary-warning:before {
    background: rgba(245, 180, 0, 0.16);
}

body.colmena-client-page .colmena-summary-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-summary-top span {
    color: #64748B;
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

body.colmena-client-page .colmena-summary-icon {
    position: static !important;
    width: 48px !important;
    height: 48px !important;
    border-radius: 17px !important;
    background: #EEF5FF !important;
    color: #124A9C !important;
    font-size: 21px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
}

body.colmena-client-page .colmena-summary-warning .colmena-summary-icon {
    background: #FFF7E6 !important;
    color: #C2410C !important;
}

body.colmena-client-page .colmena-summary-number {
    margin-top: 18px !important;
    color: #06203F !important;
    font-size: 42px !important;
    line-height: 1;
    font-weight: 950 !important;
    letter-spacing: -0.055em;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-summary-label {
    margin-top: 8px !important;
    color: #475569 !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-summary-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: auto;
    padding-top: 18px;
    color: #124A9C;
    font-size: 13px;
    font-weight: 950;
    position: relative;
    z-index: 2;
}

body.colmena-client-page .colmena-summary-footer i {
    transition: transform .18s ease;
}

body.colmena-client-page .colmena-summary-card-v3:hover .colmena-summary-footer i {
    transform: translateX(3px);
}

/* Workspace */
body.colmena-client-page .colmena-workspace-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 24px;
    align-items: start;
}

body.colmena-client-page .colmena-workspace-main {
    min-width: 0;
}

body.colmena-client-page .colmena-workspace-side {
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 100px;
}

/* Paneles WHMCS convertidos */
body.colmena-client-page .colmena-panel-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

body.colmena-client-page .colmena-panel-wide {
    margin-bottom: 22px !important;
}

body.colmena-client-page .colmena-panel-v3,
body.colmena-client-page .colmena-panel {
    border-radius: 26px !important;
    border: 1px solid rgba(226, 232, 240, 0.92) !important;
    background: rgba(255,255,255,0.92) !important;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.070) !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
}

body.colmena-client-page .colmena-panel-header {
    min-height: 62px;
    padding: 17px 20px !important;
    background: linear-gradient(180deg, #FFFFFF 0%, #FBFDFF 100%) !important;
    border-bottom: 1px solid #EAF0F7 !important;
}

body.colmena-client-page .colmena-panel-title {
    display: flex;
    align-items: center;
    color: #06203F !important;
    font-size: 15px !important;
    font-weight: 950 !important;
}

body.colmena-client-page .colmena-panel-title i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-panel-body {
    padding: 20px !important;
    color: #334155 !important;
    font-size: 14px !important;
    line-height: 1.72 !important;
}

body.colmena-client-page .colmena-panel-list .list-group-item {
    padding: 16px 20px !important;
    border-color: #EAF0F7 !important;
    color: #334155 !important;
    font-weight: 750;
}

body.colmena-client-page .colmena-panel-list .list-group-item:hover {
    background: #F8FAFC !important;
}

body.colmena-client-page .colmena-panel-footer {
    padding: 15px 20px !important;
    background: #F8FAFC !important;
    border-top: 1px solid #EAF0F7 !important;
}

body.colmena-client-page .colmena-panel-btn,
body.colmena-client-page .colmena-panel-header .btn {
    min-height: 32px !important;
    padding: 7px 12px !important;
    border-radius: 999px !important;
    background: #F5B400 !important;
    border-color: #F5B400 !important;
    color: #06203F !important;
    font-size: 11px !important;
    font-weight: 950 !important;
    box-shadow: none !important;
}

/* Side cards */
body.colmena-client-page .colmena-side-card {
    position: relative;
    padding: 22px;
    border-radius: 26px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(226, 232, 240, 0.92);
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.070);
    overflow: hidden;
}

body.colmena-client-page .colmena-side-card-payment {
    background:
        radial-gradient(circle at 100% 0%, rgba(245, 180, 0, 0.16) 0, rgba(245, 180, 0, 0) 38%),
        #FFFFFF;
}

body.colmena-client-page .colmena-side-card-help {
    background:
        radial-gradient(circle at 100% 0%, rgba(18, 74, 156, 0.12) 0, rgba(18, 74, 156, 0) 42%),
        #FFFFFF;
}

body.colmena-client-page .colmena-side-kicker {
    display: inline-flex;
    margin-bottom: 11px;
    color: #124A9C;
    font-size: 11px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

body.colmena-client-page .colmena-side-card h3 {
    margin: 0;
    color: #0F172A;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 950;
    letter-spacing: -0.035em;
}

body.colmena-client-page .colmena-side-card p {
    margin: 10px 0 0;
    color: #64748B;
    font-size: 14px;
    line-height: 1.65;
}

body.colmena-client-page .colmena-side-action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 17px;
    min-height: 38px;
    padding: 0 15px;
    border-radius: 999px;
    background: #06203F;
    color: #FFFFFF !important;
    font-size: 13px;
    font-weight: 950;
    text-decoration: none !important;
}

body.colmena-client-page .colmena-side-action:hover {
    background: #0B2E59;
}

body.colmena-client-page .colmena-quick-links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

body.colmena-client-page .colmena-quick-links a {
    display: flex;
    align-items: center;
    gap: 11px;
    min-height: 44px;
    padding: 0 13px;
    border-radius: 15px;
    background: #F8FAFC;
    border: 1px solid #EAF0F7;
    color: #334155 !important;
    font-size: 13px;
    font-weight: 900;
    text-decoration: none !important;
    transition: all .18s ease;
}

body.colmena-client-page .colmena-quick-links a:hover {
    background: #EEF5FF;
    color: #06203F !important;
    transform: translateX(2px);
}

body.colmena-client-page .colmena-quick-links i {
    width: 20px;
    color: #124A9C;
    text-align: center;
}

/* Badges */
body.colmena-client-page .badge,
body.colmena-client-page .label {
    border-radius: 999px !important;
    font-weight: 900 !important;
    padding: 6px 10px !important;
}

/* Menú usuario */
body.colmena-client-page .colmena-user-button {
    border-radius: 999px !important;
    border: 1px solid #D8E0EA !important;
    background: #FFFFFF !important;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.055);
}

body.colmena-client-page .colmena-user-button:hover {
    background: #F8FAFC !important;
    border-color: #BFD0E4 !important;
}

body.colmena-client-page .colmena-user-dropdown {
    border-radius: 22px !important;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.16) !important;
}

/* Limpieza de enlaces hosting */
body.colmena-client-page a[href*="cpanel"],
body.colmena-client-page a[href*="server"],
body.colmena-client-page a[href*="cart.php"],
body.colmena-client-page a[href*="affiliates.php"] {
    display: none !important;
}

/* Responsive */
@media (max-width: 1280px) {
    body.colmena-client-page .colmena-workspace-grid {
        grid-template-columns: minmax(0, 1fr) 300px;
    }
}

@media (max-width: 1199px) {
    body.colmena-client-page .colmena-top-main-nav {
        display: none !important;
    }

    body.colmena-client-page .colmena-workspace-grid {
        grid-template-columns: 1fr;
    }

    body.colmena-client-page .colmena-workspace-side {
        position: static;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    body.colmena-client-page section#main-body {
        padding-top: 96px !important;
    }

    body.colmena-client-page .colmena-hero-main {
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-hero-actions {
        width: 100%;
    }

    body.colmena-client-page .colmena-hero-actions .btn {
        flex: 1 1 auto;
        justify-content: center;
    }

    body.colmena-client-page .colmena-resident-card-v3 {
        align-items: flex-start;
        flex-direction: column;
        padding: 26px !important;
    }

    body.colmena-client-page .colmena-resident-status {
        width: 100%;
        justify-content: space-between;
    }

    body.colmena-client-page .colmena-summary-grid-v3 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body.colmena-client-page .colmena-panel-grid {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-workspace-side {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page section#main-body {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    body.colmena-client-page .colmena-hero-copy h1 {
        font-size: 32px !important;
    }

    body.colmena-client-page .colmena-hero-actions {
        flex-direction: column;
    }

    body.colmena-client-page .colmena-hero-actions .btn {
        width: 100%;
    }

    body.colmena-client-page .colmena-resident-main {
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-resident-info h2 {
        font-size: 24px !important;
    }

    body.colmena-client-page .colmena-resident-info p span {
        display: block;
        margin-left: 0;
        padding-left: 0;
        border-left: 0 !important;
        margin-top: 4px;
    }

    body.colmena-client-page .colmena-resident-status {
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-resident-status .btn {
        width: 100%;
    }

    body.colmena-client-page .colmena-payment-alert-v3 {
        align-items: flex-start;
        flex-direction: column;
    }

    body.colmena-client-page .colmena-alert-link {
        width: 100%;
    }

    body.colmena-client-page .colmena-summary-grid-v3 {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-summary-card-v3 {
        min-height: 158px !important;
    }
}


/* ==========================================================
   Colmena - Portal residente v3.1 refinamiento visual
   ========================================================== */

/* Ajuste general de proporción */
body.colmena-client-page .colmena-client-dashboard-v3 {
    max-width: 1220px !important;
}

body.colmena-client-page .colmena-workspace-grid {
    grid-template-columns: minmax(0, 1fr) 330px !important;
    gap: 28px !important;
}

/* Hero más compacto y premium */
body.colmena-client-page .colmena-hero-main {
    margin-bottom: 6px !important;
}

body.colmena-client-page .colmena-hero-copy h1 {
    font-size: 40px !important;
    letter-spacing: -0.06em !important;
}

body.colmena-client-page .colmena-hero-copy p {
    color: #5B6B82 !important;
}

/* Tarjeta del condominio más elegante */
body.colmena-client-page .colmena-resident-card-v3 {
    min-height: 156px !important;
    padding: 32px 34px !important;
    border-radius: 32px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.96) 58%, rgba(255,246,220,0.90) 100%) !important;
    box-shadow:
        0 30px 80px rgba(15, 23, 42, 0.09),
        inset 0 1px 0 rgba(255,255,255,0.80) !important;
}

body.colmena-client-page .colmena-resident-card-v3:before {
    top: 28px !important;
    bottom: 28px !important;
    width: 6px !important;
}

body.colmena-client-page .colmena-resident-card-v3:after {
    right: -40px !important;
    top: -70px !important;
    width: 230px !important;
    height: 230px !important;
    background: radial-gradient(circle, rgba(245,180,0,0.20) 0, rgba(245,180,0,0) 72%) !important;
}

body.colmena-client-page .colmena-resident-icon {
    width: 72px !important;
    height: 72px !important;
    border-radius: 24px !important;
}

body.colmena-client-page .colmena-resident-info h2 {
    font-size: 30px !important;
}

/* Summary cards menos genéricas */
body.colmena-client-page .colmena-summary-card-v3 {
    min-height: 178px !important;
    border-radius: 28px !important;
    padding: 22px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.96) 100%) !important;
    box-shadow:
        0 24px 58px rgba(15, 23, 42, 0.075),
        inset 0 1px 0 rgba(255,255,255,0.90) !important;
}

body.colmena-client-page .colmena-summary-card-v3:before {
    right: -32px !important;
    top: -34px !important;
    width: 112px !important;
    height: 112px !important;
    opacity: .75;
}

body.colmena-client-page .colmena-summary-card-v3:after {
    content: "";
    position: absolute;
    left: 22px;
    bottom: 18px;
    width: calc(100% - 44px);
    height: 1px;
    background: linear-gradient(90deg, rgba(18,74,156,0.12), rgba(18,74,156,0));
    pointer-events: none;
}

body.colmena-client-page .colmena-summary-top span {
    color: #6A7890 !important;
    font-size: 11px !important;
}

body.colmena-client-page .colmena-summary-number {
    font-size: 44px !important;
    margin-top: 20px !important;
}

body.colmena-client-page .colmena-summary-icon {
    width: 50px !important;
    height: 50px !important;
    border-radius: 18px !important;
}

/* Panel principal de servicios más moderno */
body.colmena-client-page .colmena-panel-wide .colmena-panel {
    border-radius: 28px !important;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item {
    display: grid !important;
    grid-template-columns: 96px minmax(0, 1fr) auto;
    align-items: center;
    gap: 16px;
    min-height: 66px;
    padding: 16px 20px !important;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item .badge,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item .label {
    justify-self: start;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item:hover {
    background: linear-gradient(90deg, #F8FAFC 0%, #FFFFFF 100%) !important;
}

/* Botones de Ver detalles más limpios */
body.colmena-client-page .colmena-panel-list .btn,
body.colmena-client-page .colmena-panel-list a.btn,
body.colmena-client-page .colmena-panel-list button {
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    padding: 7px 12px !important;
    border-color: #D8E0EA !important;
    color: #334155 !important;
    background: #FFFFFF !important;
}

/* Columna derecha más refinada */
body.colmena-client-page .colmena-workspace-side {
    gap: 20px !important;
}

body.colmena-client-page .colmena-side-card {
    border-radius: 28px !important;
    padding: 24px !important;
    box-shadow:
        0 24px 60px rgba(15, 23, 42, 0.080),
        inset 0 1px 0 rgba(255,255,255,0.90) !important;
}

body.colmena-client-page .colmena-side-card h3 {
    font-size: 21px !important;
}

body.colmena-client-page .colmena-side-action {
    min-height: 42px !important;
    padding: 0 17px !important;
}

/* Accesos rápidos más premium */
body.colmena-client-page .colmena-quick-links {
    gap: 11px !important;
}

body.colmena-client-page .colmena-quick-links a {
    min-height: 48px !important;
    border-radius: 17px !important;
    background: #F8FAFC !important;
    border-color: #E5ECF5 !important;
}

body.colmena-client-page .colmena-quick-links a:hover {
    background: #EEF5FF !important;
    border-color: #D6E5FA !important;
}

/* Paneles inferiores */
body.colmena-client-page .colmena-panel-grid {
    gap: 24px !important;
}

body.colmena-client-page .colmena-panel {
    border-radius: 28px !important;
    box-shadow:
        0 24px 60px rgba(15, 23, 42, 0.075),
        inset 0 1px 0 rgba(255,255,255,0.90) !important;
}

body.colmena-client-page .colmena-panel-header {
    min-height: 64px !important;
}

body.colmena-client-page .colmena-panel-body {
    min-height: 92px;
}

/* Menú lateral, estado activo más elegante */
body.colmena-client-page .colmena-app-nav-item.active,
body.colmena-client-page .colmena-app-nav-item.active:first-child {
    background: linear-gradient(135deg, #06203F 0%, #0B2E59 100%) !important;
}

/* Evitar que textos largos rompan la tabla de servicios */
body.colmena-client-page .colmena-panel-list .list-group-item {
    overflow: hidden;
}

body.colmena-client-page .colmena-panel-list .list-group-item a,
body.colmena-client-page .colmena-panel-list .list-group-item span,
body.colmena-client-page .colmena-panel-list .list-group-item div {
    min-width: 0;
}

/* Responsive */
@media (max-width: 1199px) {
    body.colmena-client-page .colmena-workspace-grid {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-workspace-side {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-workspace-side {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-resident-card-v3 {
        padding: 26px !important;
    }

    body.colmena-client-page .colmena-summary-card-v3 {
        min-height: 164px !important;
    }
}


/* ==========================================================
   Colmena - Portal residente v3.2 light SaaS refinado
   Corrige ancho, cards, iconos y panel de servicios
   ========================================================== */

/* Layout más ancho */
body.colmena-client-page section#main-body > .container {
    max-width: 1520px !important;
    width: 100% !important;
}

body.colmena-client-page .colmena-client-dashboard-v3,
body.colmena-client-page .colmena-client-dashboard {
    max-width: 1380px !important;
    width: 100% !important;
    margin: 0 auto !important;
}

body.colmena-client-page .colmena-workspace-grid {
    grid-template-columns: minmax(0, 1fr) 340px !important;
    gap: 30px !important;
}

/* Dar más espacio al área principal */
body.colmena-client-page .colmena-workspace-main {
    min-width: 0 !important;
}

body.colmena-client-page .colmena-workspace-side {
    min-width: 320px !important;
}

/* Hero más amplio */
body.colmena-client-page .colmena-hero-main {
    max-width: 100% !important;
}

body.colmena-client-page .colmena-resident-card-v3 {
    width: 100% !important;
}

/* Cards de métricas más limpias, sin círculos deformados */
body.colmena-client-page .colmena-summary-grid-v3 {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 20px !important;
}

body.colmena-client-page .colmena-summary-card-v3 {
    min-height: 168px !important;
    padding: 22px !important;
    border-radius: 24px !important;
    background: #FFFFFF !important;
    border: 1px solid #E4EAF2 !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.065) !important;
}

/* Quitar los círculos grandes de fondo */
body.colmena-client-page .colmena-summary-card-v3:before,
body.colmena-client-page .colmena-summary-card-v3:after {
    display: none !important;
}

/* Encabezado de card */
body.colmena-client-page .colmena-summary-top {
    align-items: flex-start !important;
}

body.colmena-client-page .colmena-summary-top span {
    color: #6B7A90 !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: 0.07em !important;
}

/* Iconos modernos, más limpios */
body.colmena-client-page .colmena-summary-icon {
    width: 44px !important;
    height: 44px !important;
    border-radius: 14px !important;
    background: #F1F6FF !important;
    color: #124A9C !important;
    font-size: 18px !important;
    box-shadow: inset 0 0 0 1px rgba(18, 74, 156, 0.08) !important;
}

body.colmena-client-page .colmena-summary-warning .colmena-summary-icon {
    background: #FFF7E6 !important;
    color: #C2410C !important;
    box-shadow: inset 0 0 0 1px rgba(194, 65, 12, 0.10) !important;
}

body.colmena-client-page .colmena-summary-number {
    margin-top: 18px !important;
    font-size: 40px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    color: #06203F !important;
}

body.colmena-client-page .colmena-summary-label {
    margin-top: 8px !important;
    color: #334155 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
}

body.colmena-client-page .colmena-summary-footer {
    margin-top: auto !important;
    padding-top: 18px !important;
    border-top: 1px solid #EEF2F7 !important;
    color: #124A9C !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}

/* Paneles más anchos y más limpios */
body.colmena-client-page .colmena-panel,
body.colmena-client-page .colmena-panel-v3 {
    border-radius: 24px !important;
    background: #FFFFFF !important;
    border: 1px solid #E4EAF2 !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.060) !important;
}

/* Encabezado del panel de servicios */
body.colmena-client-page .colmena-panel-wide .colmena-panel-header {
    min-height: 64px !important;
    padding: 18px 22px !important;
    background: #FFFFFF !important;
    border-bottom: 1px solid #E8EEF6 !important;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-title {
    font-size: 16px !important;
    font-weight: 950 !important;
    color: #06203F !important;
}

/* IMPORTANTE: revertir el grid que rompió las filas */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    min-height: 78px !important;
    padding: 18px 22px !important;
    border-color: #E8EEF6 !important;
    color: #1E293B !important;
    background: #FFFFFF !important;
    overflow: visible !important;
    white-space: normal !important;
}

/* Texto del servicio legible */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item * {
    color: #1E293B;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item:hover {
    background: #F8FAFC !important;
}

/* Badge de estado */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .badge,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .label {
    flex: 0 0 auto !important;
    min-width: 76px !important;
    text-align: center !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    padding: 7px 10px !important;
    border-radius: 999px !important;
}

/* Evitar que el texto se pierda */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item > span,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item > div,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item > a:not(.btn) {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

/* Botón de detalle alineado */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .btn,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list a.btn,
body.colmena-client-page .colmena-panel-wide .colmena-panel-list button {
    margin-left: auto !important;
    flex: 0 0 auto !important;
    min-height: 36px !important;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    background: #FFFFFF !important;
    border: 1px solid #CBD5E1 !important;
    color: #334155 !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

/* Si WHMCS pone enlaces internos dentro del item */
body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item a:not(.btn) {
    color: #1E293B !important;
    font-weight: 850 !important;
    text-decoration: none !important;
}

/* Footer "Ver detalles..." */
body.colmena-client-page .colmena-panel-wide .colmena-panel-footer {
    padding: 16px 22px !important;
    background: #F8FAFC !important;
    border-top: 1px solid #E8EEF6 !important;
}

body.colmena-client-page .colmena-panel-wide .colmena-panel-footer a,
body.colmena-client-page .colmena-panel-wide .colmena-panel-footer {
    color: #334155 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
}

/* Tarjetas inferiores */
body.colmena-client-page .colmena-panel-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
}

body.colmena-client-page .colmena-panel-grid .colmena-panel {
    min-height: 150px !important;
}

body.colmena-client-page .colmena-panel-header {
    min-height: 62px !important;
    padding: 18px 22px !important;
}

body.colmena-client-page .colmena-panel-body {
    padding: 20px 22px !important;
}

/* Columna derecha */
body.colmena-client-page .colmena-side-card {
    border-radius: 24px !important;
    background: #FFFFFF !important;
    border: 1px solid #E4EAF2 !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.060) !important;
}

body.colmena-client-page .colmena-side-card-payment {
    background: linear-gradient(135deg, #FFFFFF 0%, #FFF8E8 100%) !important;
}

body.colmena-client-page .colmena-side-card-help {
    background: linear-gradient(135deg, #FFFFFF 0%, #F1F6FF 100%) !important;
}

/* Responsive */
@media (max-width: 1320px) {
    body.colmena-client-page .colmena-client-dashboard-v3,
    body.colmena-client-page .colmena-client-dashboard {
        max-width: 100% !important;
    }

    body.colmena-client-page .colmena-workspace-grid {
        grid-template-columns: minmax(0, 1fr) 320px !important;
    }
}

@media (max-width: 1199px) {
    body.colmena-client-page .colmena-workspace-grid {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-workspace-side {
        min-width: 0 !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 991px) {
    body.colmena-client-page .colmena-summary-grid-v3 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body.colmena-client-page .colmena-workspace-side {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-panel-wide .colmena-panel-list .list-group-item {
        align-items: flex-start !important;
        flex-direction: column !important;
    }

    body.colmena-client-page .colmena-panel-wide .colmena-panel-list .btn,
    body.colmena-client-page .colmena-panel-wide .colmena-panel-list a.btn,
    body.colmena-client-page .colmena-panel-wide .colmena-panel-list button {
        margin-left: 0 !important;
    }
}

@media (max-width: 575px) {
    body.colmena-client-page .colmena-summary-grid-v3 {
        grid-template-columns: 1fr !important;
    }

    body.colmena-client-page .colmena-panel-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ==========================================================
   Colmena - Vista Facturación / Invoices moderna
   Área cliente Lagom / WHMCS
   ========================================================== */

/* Vista de facturas más ancha */
body.colmena-client-page.clientarea-invoices section#main-body > .container,
body.colmena-client-page section#main-body > .container {
    max-width: 1520px !important;
    width: 100% !important;
}

body.colmena-client-page .main-content,
body.colmena-client-page .primary-content {
    max-width: 100% !important;
}

/* Contenedor de DataTables */
body.colmena-client-page .dataTables_wrapper {
    position: relative;
    background: #FFFFFF !important;
    border: 1px solid #E4EAF2 !important;
    border-radius: 28px !important;
    box-shadow: 0 24px 65px rgba(15, 23, 42, 0.075) !important;
    overflow: hidden !important;
    padding: 0 !important;
}

/* Crear sensación de módulo */
body.colmena-client-page .dataTables_wrapper:before {
    content: "Mis facturas";
    display: block;
    padding: 24px 28px 6px;
    color: #06203F;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 950;
    letter-spacing: -0.045em;
}

body.colmena-client-page .dataTables_wrapper:after {
    content: "Consulta el estado de tus facturas, fechas de vencimiento y pagos realizados.";
    display: block;
    padding: 0 28px 22px;
    color: #64748B;
    font-size: 14px;
    font-weight: 600;
    border-bottom: 1px solid #E8EEF6;
}

/* Línea superior de controles */
body.colmena-client-page .dataTables_length,
body.colmena-client-page .dataTables_filter {
    position: relative;
    z-index: 2;
    margin: 0 !important;
    padding: 18px 28px !important;
    background: #FFFFFF !important;
}

body.colmena-client-page .dataTables_length {
    float: left !important;
    color: #475569 !important;
    font-size: 14px;
    font-weight: 700;
}

body.colmena-client-page .dataTables_filter {
    float: right !important;
}

body.colmena-client-page .dataTables_filter label {
    margin: 0 !important;
    color: transparent !important;
    font-size: 0 !important;
}

body.colmena-client-page .dataTables_filter input {
    width: 280px !important;
    height: 46px !important;
    margin: 0 !important;
    padding: 0 16px 0 44px !important;
    border: 1px solid #D8E0EA !important;
    border-radius: 999px !important;
    background:
        url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.875 18.75C15.2242 18.75 18.75 15.2242 18.75 10.875C18.75 6.52576 15.2242 3 10.875 3C6.52576 3 3 6.52576 3 10.875C3 15.2242 6.52576 18.75 10.875 18.75Z' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M16.4434 16.4434L21.0001 21.0001' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
        no-repeat 16px center,
        #F8FAFC !important;
    color: #0F172A !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    box-shadow: none !important;
    outline: none !important;
}

body.colmena-client-page .dataTables_filter input:focus {
    background-color: #FFFFFF !important;
    border-color: #124A9C !important;
    box-shadow: 0 0 0 4px rgba(18, 74, 156, 0.10) !important;
}

body.colmena-client-page .dataTables_length select {
    height: 40px !important;
    min-width: 72px !important;
    margin: 0 8px !important;
    border: 1px solid #D8E0EA !important;
    border-radius: 12px !important;
    background: #F8FAFC !important;
    color: #0F172A !important;
    font-weight: 800 !important;
}

/* Tabla */
body.colmena-client-page table.table,
body.colmena-client-page table.dataTable {
    width: 100% !important;
    margin: 0 !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    background: #FFFFFF !important;
    border-radius: 0 !important;
    overflow: hidden !important;
}

body.colmena-client-page table.dataTable thead th,
body.colmena-client-page table.table thead th {
    padding: 17px 18px !important;
    background: #F8FAFC !important;
    border-top: 1px solid #E8EEF6 !important;
    border-bottom: 1px solid #E8EEF6 !important;
    color: #475569 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}

body.colmena-client-page table.dataTable tbody td,
body.colmena-client-page table.table tbody td {
    padding: 18px !important;
    border-top: 0 !important;
    border-bottom: 1px solid #E8EEF6 !important;
    color: #1E293B !important;
    font-size: 14px !important;
    font-weight: 650 !important;
    vertical-align: middle !important;
    background: #FFFFFF !important;
}

body.colmena-client-page table.dataTable tbody tr {
    transition: background .16s ease, transform .16s ease;
}

body.colmena-client-page table.dataTable tbody tr:hover td,
body.colmena-client-page table.table tbody tr:hover td {
    background: #F8FAFC !important;
}

/* Factura número */
body.colmena-client-page table.dataTable tbody td:first-child,
body.colmena-client-page table.table tbody td:first-child {
    color: #06203F !important;
    font-weight: 950 !important;
}

/* Total */
body.colmena-client-page table.dataTable tbody td:nth-child(4),
body.colmena-client-page table.table tbody td:nth-child(4) {
    color: #06203F !important;
    font-weight: 950 !important;
}

/* Estado */
body.colmena-client-page table.dataTable tbody td:last-child,
body.colmena-client-page table.table tbody td:last-child {
    white-space: nowrap;
}

/* Badges de estado */
body.colmena-client-page .label,
body.colmena-client-page .badge,
body.colmena-client-page span.label,
body.colmena-client-page span.badge {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 30px !important;
    padding: 0 13px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    box-shadow: none !important;
}

/* WHMCS suele usar clases Bootstrap */
body.colmena-client-page .label-success,
body.colmena-client-page .badge-success,
body.colmena-client-page .status-paid,
body.colmena-client-page .paid {
    background: #ECFDF5 !important;
    color: #047857 !important;
    border: 1px solid #BBF7D0 !important;
}

body.colmena-client-page .label-danger,
body.colmena-client-page .badge-danger,
body.colmena-client-page .status-unpaid,
body.colmena-client-page .unpaid {
    background: #FEF2F2 !important;
    color: #DC2626 !important;
    border: 1px solid #FECACA !important;
}

body.colmena-client-page .label-warning,
body.colmena-client-page .badge-warning,
body.colmena-client-page .status-pending {
    background: #FFF7E6 !important;
    color: #C2410C !important;
    border: 1px solid #FED7AA !important;
}

/* Ordenamiento DataTables menos feo */
body.colmena-client-page table.dataTable thead .sorting,
body.colmena-client-page table.dataTable thead .sorting_asc,
body.colmena-client-page table.dataTable thead .sorting_desc {
    background-image: none !important;
    position: relative;
}

body.colmena-client-page table.dataTable thead .sorting:after,
body.colmena-client-page table.dataTable thead .sorting_asc:after,
body.colmena-client-page table.dataTable thead .sorting_desc:after {
    content: "↕";
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #94A3B8;
    font-size: 12px;
}

body.colmena-client-page table.dataTable thead .sorting_asc:after {
    content: "↑";
    color: #124A9C;
}

body.colmena-client-page table.dataTable thead .sorting_desc:after {
    content: "↓";
    color: #124A9C;
}

/* Footer de tabla */
body.colmena-client-page .dataTables_info,
body.colmena-client-page .dataTables_paginate {
    padding: 18px 28px !important;
    margin: 0 !important;
    color: #64748B !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    background: #FFFFFF !important;
}

body.colmena-client-page .dataTables_paginate {
    float: right !important;
}

body.colmena-client-page .dataTables_info {
    float: left !important;
}

/* Paginación */
body.colmena-client-page .dataTables_paginate .paginate_button,
body.colmena-client-page .pagination > li > a,
body.colmena-client-page .pagination > li > span {
    min-width: 40px !important;
    height: 40px !important;
    padding: 0 12px !important;
    margin: 0 3px !important;
    border: 1px solid #D8E0EA !important;
    border-radius: 12px !important;
    background: #FFFFFF !important;
    color: #334155 !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-decoration: none !important;
}

body.colmena-client-page .dataTables_paginate .paginate_button.current,
body.colmena-client-page .dataTables_paginate .paginate_button.current:hover,
body.colmena-client-page .pagination > .active > a,
body.colmena-client-page .pagination > .active > span {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 10px 22px rgba(6, 32, 63, 0.18);
}

body.colmena-client-page .dataTables_paginate .paginate_button:hover,
body.colmena-client-page .pagination > li > a:hover {
    background: #EEF5FF !important;
    border-color: #BFD0E4 !important;
    color: #06203F !important;
}

/* Limpiar esquinas de tabla */
body.colmena-client-page .table-responsive {
    border: 0 !important;
    margin: 0 !important;
}

/* Responsive */
@media (max-width: 991px) {
    body.colmena-client-page .dataTables_wrapper:before {
        padding: 22px 20px 6px;
        font-size: 22px;
    }

    body.colmena-client-page .dataTables_wrapper:after {
        padding: 0 20px 18px;
    }

    body.colmena-client-page .dataTables_length,
    body.colmena-client-page .dataTables_filter {
        float: none !important;
        width: 100% !important;
        padding: 12px 20px !important;
    }

    body.colmena-client-page .dataTables_filter input {
        width: 100% !important;
    }

    body.colmena-client-page .dataTables_info,
    body.colmena-client-page .dataTables_paginate {
        float: none !important;
        width: 100% !important;
        text-align: center !important;
        padding: 12px 20px !important;
    }

    body.colmena-client-page table.dataTable {
        min-width: 850px;
    }

    body.colmena-client-page .dataTables_wrapper {
        overflow-x: auto !important;
    }
}


/* ==========================================================
   Colmena - Fix global para páginas del portal residente
   Evita doble layout en submitticket, tickets y soporte
   ========================================================== */

/* Ocultar header nativo de WHMCS / Lagom en portal residente */
body.colmena-client-page header#header,
body.colmena-client-page #header,
body.colmena-client-page .navbar-main,
body.colmena-client-page .navbar,
body.colmena-client-page .topbar,
body.colmena-client-page .master-breadcrumb,
body.colmena-client-page .breadcrumb,
body.colmena-client-page .header-lined,
body.colmena-client-page .adminreturndiv,
body.colmena-client-page .btn-return-to-admin {
    display: none !important;
}

/* Ocultar footer nativo */
body.colmena-client-page footer.footer,
body.colmena-client-page .footer,
body.colmena-client-page .main-footer,
body.colmena-client-page .powered-by,
body.colmena-client-page .poweredby,
body.colmena-client-page p:has(a[href*="whmcs"]),
body.colmena-client-page p:has(a[href*="WHMCompleteSolution"]) {
    display: none !important;
}

/* Si por alguna razón el body no recibe la clase, pero existe el layout Colmena */
.colmena-app-sidebar,
.colmena-app-topbar {
    box-sizing: border-box;
}

/* Sidebar siempre en formato app */
body.colmena-client-page .colmena-app-sidebar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 248px !important;
    height: 100vh !important;
    background: #FFFFFF !important;
    border-right: 1px solid #E6ECF3 !important;
    box-shadow: 18px 0 45px rgba(15, 23, 42, 0.045) !important;
    z-index: 1200 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

/* Logo del sidebar, evita logo gigante */
body.colmena-client-page .colmena-app-logo {
    height: 94px !important;
    padding: 0 26px !important;
    display: flex !important;
    align-items: center !important;
    border-bottom: 1px solid #EEF2F7 !important;
}

body.colmena-client-page .colmena-app-logo img {
    max-width: 170px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
}

/* Menú lateral */
body.colmena-client-page .colmena-app-nav {
    padding: 22px 14px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 7px !important;
}

body.colmena-client-page .colmena-app-nav-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 48px !important;
    padding: 0 14px !important;
    border-radius: 16px !important;
    color: #334155 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 850 !important;
}

body.colmena-client-page .colmena-app-nav-item i {
    width: 22px !important;
    text-align: center !important;
    color: #124A9C !important;
}

body.colmena-client-page .colmena-app-nav-item.active,
body.colmena-client-page .colmena-app-nav-item:hover {
    background: #06203F !important;
    color: #FFFFFF !important;
}

body.colmena-client-page .colmena-app-nav-item.active i,
body.colmena-client-page .colmena-app-nav-item:hover i {
    color: #FFFFFF !important;
}

/* Footer del sidebar */
body.colmena-client-page .colmena-app-sidebar-footer {
    margin-top: auto !important;
    padding: 16px 14px 22px !important;
    border-top: 1px solid #EEF2F7 !important;
}

body.colmena-client-page .colmena-logout {
    color: #B91C1C !important;
}

/* Topbar siempre correcta */
body.colmena-client-page .colmena-app-topbar {
    position: fixed !important;
    top: 0 !important;
    left: 248px !important;
    right: 0 !important;
    height: 76px !important;
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    border-bottom: 1px solid #E6ECF3 !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.045) !important;
    z-index: 1100 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 34px !important;
}

/* Evitar que el logo móvil se vea gigante en desktop */
body.colmena-client-page .colmena-mobile-topbar-brand {
    display: none !important;
}

/* Contenido principal */
body.colmena-client-page section#main-body {
    margin-left: 248px !important;
    padding-top: 112px !important;
    min-height: 100vh !important;
    background:
        radial-gradient(circle at 14% 8%, rgba(18, 74, 156, 0.10) 0, rgba(18, 74, 156, 0) 30%),
        radial-gradient(circle at 92% 18%, rgba(245, 180, 0, 0.16) 0, rgba(245, 180, 0, 0) 26%),
        linear-gradient(180deg, #F8FAFD 0%, #EFF4FA 100%) !important;
}

/* Quitar columnas laterales nativas */
body.colmena-client-page section#main-body > .container > .row > .col-lg-4,
body.colmena-client-page section#main-body > .container > .row > .col-xl-3,
body.colmena-client-page .sidebar {
    display: none !important;
}

body.colmena-client-page section#main-body > .container > .row > .primary-content,
body.colmena-client-page section#main-body > .container > .row > .col-lg-8,
body.colmena-client-page section#main-body > .container > .row > .col-xl-9 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Contenedor principal más amplio */
body.colmena-client-page section#main-body > .container {
    max-width: 1320px !important;
    width: 100% !important;
}

/* Cards/formularios de soporte */
body.colmena-client-page .card,
body.colmena-client-page .panel,
body.colmena-client-page .ticket-reply,
body.colmena-client-page .ticket-details,
body.colmena-client-page .submit-ticket,
body.colmena-client-page .main-content .card {
    border: 1px solid #E4EAF2 !important;
    border-radius: 24px !important;
    background: #FFFFFF !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.060) !important;
    overflow: hidden !important;
}

/* Mensaje de ticket creado */
body.colmena-client-page .alert-success,
body.colmena-client-page .alert.alert-success {
    border-radius: 18px !important;
    border: 1px solid #BBF7D0 !important;
    background: #ECFDF5 !important;
    color: #047857 !important;
    font-weight: 900 !important;
}

/* Botón continuar */
body.colmena-client-page a.btn,
body.colmena-client-page button.btn,
body.colmena-client-page input.btn {
    border-radius: 14px !important;
    font-weight: 850 !important;
}

/* Responsive */
@media (max-width: 991px) {
    body.colmena-client-page .colmena-app-sidebar {
        transform: translateX(-100%) !important;
        transition: transform .22s ease !important;
    }

    body.colmena-client-page.colmena-menu-open .colmena-app-sidebar {
        transform: translateX(0) !important;
    }

    body.colmena-client-page .colmena-app-topbar {
        left: 0 !important;
        padding: 0 16px !important;
    }

    body.colmena-client-page .colmena-mobile-topbar-brand {
        display: flex !important;
    }

    body.colmena-client-page section#main-body {
        margin-left: 0 !important;
        padding-top: 96px !important;
    }
}


.colmena-client-stat::after {
  content: "";
  position: absolute;
  right: -28px;
  bottom: -25px;
  width: 108px;
  height: 150px !important;
  border-radius: 999px;
  background: rgba(11, 95, 255, .055);
  
}


/* Colmena - corrección de navegación activa del portal */
.colmena-app-nav .colmena-app-nav-item:not(.active) {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
}

.colmena-app-nav .colmena-app-nav-item:not(.active) i,
.colmena-app-nav .colmena-app-nav-item:not(.active) span {
    color: inherit !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.colmena-app-nav .colmena-app-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 10px 24px rgba(6, 32, 63, .18) !important;
}

.colmena-app-nav .colmena-app-nav-item.active i,
.colmena-app-nav .colmena-app-nav-item.active span {
    color: #FFFFFF !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.colmena-top-main-nav .colmena-top-main-nav-item:not(.active) {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
}

.colmena-top-main-nav .colmena-top-main-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    border-radius: 999px !important;
    box-shadow: 0 10px 24px rgba(6, 32, 63, .18) !important;
}

.colmena-app-topbar-actions .colmena-topbar-utility-link {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.colmena-app-topbar-actions .colmena-topbar-utility-link i {
    color: inherit !important;
}

.colmena-app-topbar-actions .colmena-whatsapp-link {
    color: #0F9F4A !important;
}


/* Colmena - limpiar estados activos falsos */
.colmena-app-nav .colmena-app-nav-item {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
}

.colmena-app-nav .colmena-app-nav-item i,
.colmena-app-nav .colmena-app-nav-item span {
    color: inherit !important;
}

.colmena-app-nav .colmena-app-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 10px 24px rgba(6, 32, 63, .18) !important;
}

.colmena-app-nav .colmena-app-nav-item.active i,
.colmena-app-nav .colmena-app-nav-item.active span {
    color: #FFFFFF !important;
}

.colmena-top-main-nav .colmena-top-main-nav-item {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
}

.colmena-top-main-nav .colmena-top-main-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    border-radius: 999px !important;
    box-shadow: 0 10px 24px rgba(6, 32, 63, .18) !important;
}

.colmena-app-topbar-actions a {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
}

.colmena-app-topbar-actions a[href*="wa.me"] {
    color: #0F9F4A !important;
}


/* Colmena - navegación activa definitiva */
body.colmena-client-page .colmena-app-nav .colmena-app-nav-item {
    background: transparent !important;
    color: #334155 !important;
    box-shadow: none !important;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item i,
body.colmena-client-page .colmena-app-nav .colmena-app-nav-item span {
    color: inherit !important;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item i {
    color: #124A9C !important;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    box-shadow: 0 14px 28px rgba(6, 32, 63, 0.18) !important;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item.active i,
body.colmena-client-page .colmena-app-nav .colmena-app-nav-item.active span {
    color: #FFFFFF !important;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item.active:before {
    content: "";
    position: absolute;
    left: -14px;
    top: 11px;
    width: 4px;
    height: 26px;
    border-radius: 999px;
    background: #F5B400;
}

body.colmena-client-page .colmena-app-nav .colmena-app-nav-item:not(.active):before {
    display: none !important;
}

body.colmena-client-page .colmena-top-main-nav .colmena-top-main-nav-item {
    background: transparent !important;
    color: #475569 !important;
    box-shadow: none !important;
}

body.colmena-client-page .colmena-top-main-nav .colmena-top-main-nav-item.active {
    background: #06203F !important;
    color: #FFFFFF !important;
    border-radius: 999px !important;
    box-shadow: 0 12px 24px rgba(6, 32, 63, 0.18) !important;
}

body.colmena-client-page .colmena-app-topbar-actions .colmena-topbar-utility-link {
    background: transparent !important;
    color: #06203F !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

body.colmena-client-page .colmena-app-topbar-actions .colmena-whatsapp-link {
    color: #0F9F4A !important;
}


/* ==========================================================
   Colmena - Login estilo portal residente premium
   Imagen: /templates/colmena/assets/img/colmena-login-bg.jpg
   ========================================================== */

body.colmena-login-page {
    background: #ffffff !important;
    overflow-x: hidden;
}

body.colmena-login-page header,
body.colmena-login-page .navbar,
body.colmena-login-page .navbar-main,
body.colmena-login-page .topbar,
body.colmena-login-page .master-breadcrumb,
body.colmena-login-page footer.footer,
body.colmena-login-page .adminreturndiv,
body.colmena-login-page .btn-return-to-admin,
body.colmena-login-page a[href*="returntoadmin"] {
    display: none !important;
}

body.colmena-login-page section#main-body {
    min-height: 100vh;
    padding: 0 !important;
    background: #ffffff !important;
    position: relative;
    overflow: hidden;
}

body.colmena-login-page section#main-body:before {
    content: "";
    position: fixed;
    inset: 0 auto 0 0;
    width: 44%;
    min-width: 520px;
    height: 100vh;
    background:
        linear-gradient(180deg, rgba(6, 32, 63, 0.30) 0%, rgba(6, 32, 63, 0.70) 100%),
        url("/templates/colmena/img/colmena-login-bg.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    z-index: 0;
}

body.colmena-login-page section#main-body:after {
    content: "Bienvenido a Colmena\A\A Consulta tus facturas, realiza pagos, revisa consumos y abre solicitudes desde un solo lugar.\A\A Un portal privado para residentes, simple, seguro y fácil de usar.";
    white-space: pre-line;
    position: fixed;
    left: 5.5%;
    top: 29%;
    width: 29%;
    max-width: 500px;
    color: #ffffff;
    font-size: 20px;
    line-height: 1.75;
    font-weight: 400;
    z-index: 1;
}

body.colmena-login-page section#main-body > .container:before {
    content: "";
    position: fixed;
    left: 5.5%;
    top: 64px;
    width: 170px;
    height: 82px;
    background-image: url("/templates/colmena/img/Colmena-Logo-Login.png");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left center;
    z-index: 3;
}

body.colmena-login-page section#main-body > .container {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    position: relative;
    z-index: 2;
}

body.colmena-login-page section#main-body > .container > .row {
    width: 100%;
    min-height: 100vh;
    margin: 0 !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.colmena-login-page section#main-body > .container > .row > .primary-content {
    width: 56% !important;
    max-width: 56% !important;
    flex: 0 0 56% !important;
    min-height: 100vh;
    margin-left: 44% !important;
    padding: 60px 80px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.colmena-login-page .colmena-login-shell {
    width: 100%;
    display: flex;
    justify-content: center;
}

body.colmena-login-page .colmena-login-form {
    width: 100%;
    max-width: 560px !important;
}

body.colmena-login-page .colmena-login-card {
    width: 100%;
    max-width: 560px !important;
    background: #ffffff;
    border: 1px solid #E5EAF2;
    border-radius: 28px;
    box-shadow: 0 36px 95px rgba(15, 23, 42, 0.13);
    overflow: hidden;
}

body.colmena-login-page .colmena-login-card-body {
    padding: 44px 46px 38px;
}

body.colmena-login-page .colmena-login-heading {
    margin-bottom: 30px;
}

body.colmena-login-page .colmena-login-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    margin-bottom: 14px;
    color: #124A9C;
    background: #EAF2FF;
    border-radius: 999px;
    padding: 0 13px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.02em;
}

body.colmena-login-page .colmena-login-heading h1 {
    margin: 0 0 10px;
    color: #0F172A;
    font-size: 36px;
    line-height: 1.12;
    font-weight: 900;
    letter-spacing: -0.04em;
}

body.colmena-login-page .colmena-login-heading p {
    margin: 0;
    color: #64748B;
    font-size: 15px;
    line-height: 1.65;
}

body.colmena-login-page .colmena-form-group {
    margin-bottom: 20px;
}

body.colmena-login-page .colmena-form-group label {
    display: block;
    color: #1E293B;
    font-size: 14px;
    font-weight: 800;
    margin-bottom: 9px;
}

body.colmena-login-page .colmena-password-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

body.colmena-login-page .colmena-forgot-link {
    color: #124A9C !important;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}

body.colmena-login-page .colmena-forgot-link:hover {
    text-decoration: underline;
}

body.colmena-login-page .colmena-input-group {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
}

body.colmena-login-page .colmena-input-group .input-group-prepend,
body.colmena-login-page .colmena-input-group .input-group-append {
    display: flex !important;
    flex: 0 0 54px !important;
    width: 54px !important;
    max-width: 54px !important;
}

body.colmena-login-page .colmena-input-group .input-group-text {
    width: 54px !important;
    min-width: 54px !important;
    max-width: 54px !important;
    height: 56px !important;
    min-height: 56px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 15px 0 0 15px !important;
    border: 1px solid #D8E0EA !important;
    background: #F8FAFC !important;
    color: #06203F !important;
}

body.colmena-login-page .colmena-input-group .form-control {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 56px !important;
    min-height: 56px !important;
    border: 1px solid #D8E0EA !important;
    border-left: 0 !important;
    background: #ffffff !important;
    color: #0F172A !important;
    box-shadow: none !important;
    border-radius: 0 15px 15px 0 !important;
    font-size: 15px !important;
}

body.colmena-login-page .colmena-input-group .form-control:focus {
    border-color: #124A9C !important;
    box-shadow: 0 0 0 4px rgba(18, 74, 156, 0.10) !important;
}

body.colmena-login-page .colmena-input-group .form-control.pw-input {
    border-radius: 0 !important;
    border-right: 0 !important;
}

body.colmena-login-page .colmena-input-group .input-group-append .btn,
body.colmena-login-page .colmena-reveal-pw {
    width: 54px !important;
    min-width: 54px !important;
    max-width: 54px !important;
    height: 56px !important;
    min-height: 56px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 0 15px 15px 0 !important;
    border: 1px solid #D8E0EA !important;
    background: #ffffff !important;
    color: #334155 !important;
}

body.colmena-login-page .colmena-login-actions {
    margin-top: 8px;
}

body.colmena-login-page .colmena-login-button {
    display: block !important;
    width: 100% !important;
    min-height: 58px !important;
    background: #06203F !important;
    border-color: #06203F !important;
    color: #ffffff !important;
    border-radius: 15px !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    box-shadow: 0 16px 30px rgba(6, 32, 63, 0.24);
}

body.colmena-login-page .colmena-login-button:hover {
    background: #0B2E59 !important;
    border-color: #0B2E59 !important;
}

body.colmena-login-page .colmena-remember {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 18px 0 0;
    color: #475569;
    font-size: 14px;
    font-weight: 500;
}

body.colmena-login-page .colmena-remember input {
    margin: 0 !important;
    width: 16px;
    height: 16px;
}

body.colmena-login-page .primary-content > p,
body.colmena-login-page p.text-center,
body.colmena-login-page p.text-muted,
body.colmena-login-page .powered-by,
body.colmena-login-page .poweredby {
    display: none !important;
}

@media (max-width: 991px) {
    body.colmena-login-page section#main-body:before,
    body.colmena-login-page section#main-body:after {
        display: none !important;
    }

    body.colmena-login-page section#main-body {
        background: #F4F7FB !important;
    }

    body.colmena-login-page section#main-body > .container:before {
        display: block !important;
        position: relative;
        left: auto;
        top: auto;
        width: 190px;
        height: 78px;
        margin: 28px auto 12px;
        background-image: url("/templates/colmena/img/Colmena-Logo-dark.png");
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
        z-index: 3;
    }

    body.colmena-login-page section#main-body > .container > .row {
        min-height: auto;
        display: block;
    }

    body.colmena-login-page section#main-body > .container > .row > .primary-content {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        min-height: auto;
        margin-left: 0 !important;
        padding: 20px 24px 42px !important;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    body.colmena-login-page .colmena-login-card {
        border-radius: 24px;
    }

    body.colmena-login-page .colmena-login-card-body {
        padding: 34px 28px 30px;
    }

    body.colmena-login-page .colmena-login-heading h1 {
        font-size: 30px;
    }
}

@media (max-width: 575px) {
    body.colmena-login-page section#main-body > .container:before {
        width: 165px;
        height: 68px;
        margin-top: 22px;
    }

    body.colmena-login-page section#main-body > .container > .row > .primary-content {
        padding: 16px 16px 36px !important;
    }

    body.colmena-login-page .colmena-login-card-body {
        padding: 30px 22px 26px;
    }

    body.colmena-login-page .colmena-login-heading h1 {
        font-size: 28px;
    }

    body.colmena-login-page .colmena-login-heading p {
        font-size: 14px;
    }
}


/* ==========================================================
   Colmena - Texto lateral login como referencia
   ========================================================== */

body.colmena-login-page section#main-body:after {
    display: none !important;
}

body.colmena-login-page .colmena-login-side-copy {
    position: fixed;
    left: 5.5%;
    top: 39%;
    width: 33%;
    max-width: 540px;
    color: #ffffff;
    z-index: 3;
}

body.colmena-login-page .colmena-login-side-copy h2 {
    margin: 0 0 16px;
    color: #ffffff;
    font-size: 40px;
    line-height: 1.05;
    font-weight: 900;
    letter-spacing: -0.04em;
}

body.colmena-login-page .colmena-login-side-copy span {
    display: block;
    margin-bottom: 34px;
    color: rgba(255,255,255,0.72);
    font-size: 12px;
    line-height: 1;
    font-weight: 500;
}

body.colmena-login-page .colmena-login-side-copy h3 {
    margin: 0 0 22px;
    color: #ffffff;
    font-size: 31px;
    line-height: 1.22;
    font-weight: 900;
    letter-spacing: -0.03em;
}

body.colmena-login-page .colmena-login-side-copy p {
    margin: 0;
    color: #ffffff;
    font-size: 17px;
    line-height: 1.55;
    font-weight: 500;
}

body.colmena-login-page .colmena-login-side-copy p strong {
    font-weight: 900;
}

@media (max-width: 991px) {
    body.colmena-login-page .colmena-login-side-copy {
        display: none !important;
    }
}


/* ==========================================================
   Colmena - Anuncios nativos WHMCS en login
   ========================================================== */

body.colmena-login-page .colmena-login-announcements {
    position: fixed;
    left: 5.5%;
    top: 69%;
    width: 33%;
    max-width: 540px;
    z-index: 3;
}

body.colmena-login-page .colmena-login-announcements-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

body.colmena-login-page .colmena-login-announcements-header span {
    color: rgba(255,255,255,0.82);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.colmena-login-page .colmena-login-announcements-header a {
    color: rgba(255,255,255,0.82) !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

body.colmena-login-page .colmena-login-announcements-header a:hover {
    color: #ffffff !important;
    text-decoration: underline;
}

body.colmena-login-page .colmena-login-announcement-item {
    display: block;
    padding: 14px 16px;
    margin-bottom: 10px;
    border-radius: 16px;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.14);
    color: #ffffff !important;
    text-decoration: none !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: all .18s ease;
}

body.colmena-login-page .colmena-login-announcement-item:hover {
    background: rgba(255,255,255,0.15);
    transform: translateY(-1px);
}

body.colmena-login-page .colmena-login-announcement-item small {
    display: block;
    margin-bottom: 5px;
    color: rgba(255,255,255,0.62);
    font-size: 11px;
    font-weight: 700;
}

body.colmena-login-page .colmena-login-announcement-item strong {
    display: block;
    color: #ffffff;
    font-size: 14px;
    line-height: 1.3;
    font-weight: 900;
}

body.colmena-login-page .colmena-login-announcement-item p {
    margin: 6px 0 0;
    color: rgba(255,255,255,0.76);
    font-size: 12px;
    line-height: 1.45;
    font-weight: 500;
}

@media (max-width: 991px) {
    body.colmena-login-page .colmena-login-announcements {
        display: none !important;
    }
}

/* ==========================================================
   Colmena - Página pública de anuncios
   Archivo: /templates/colmena/announcements.tpl
   ========================================================== */

body:not(.colmena-login-page) .colmena-public-announcements {
    max-width: 980px;
    margin: 0 auto;
}

body:not(.colmena-login-page) .colmena-public-hero {
    margin-bottom: 28px;
}

body:not(.colmena-login-page) .colmena-public-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 13px;
    margin-bottom: 12px;
    border-radius: 999px;
    background: #EAF2FF;
    color: #124A9C;
    border: 1px solid rgba(18, 74, 156, 0.08);
    font-size: 12px;
    font-weight: 800;
}

body:not(.colmena-login-page) .colmena-public-hero h1 {
    margin: 0;
    color: #0F172A;
    font-size: 40px;
    line-height: 1.08;
    font-weight: 900;
    letter-spacing: -0.055em;
}

body:not(.colmena-login-page) .colmena-public-hero p {
    max-width: 640px;
    margin: 12px 0 0;
    color: #64748B;
    font-size: 15px;
    line-height: 1.7;
}

body:not(.colmena-login-page) .colmena-announcements-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}

body:not(.colmena-login-page) .colmena-public-announcement-card {
    position: relative;
    padding: 28px;
    border-radius: 26px;
    background: #FFFFFF;
    border: 1px solid #E6ECF3;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.07);
    overflow: hidden;
}

body:not(.colmena-login-page) .colmena-public-announcement-card:before {
    content: "";
    position: absolute;
    left: 0;
    top: 28px;
    bottom: 28px;
    width: 5px;
    border-radius: 0 999px 999px 0;
    background: #124A9C;
}

body:not(.colmena-login-page) .colmena-public-announcement-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
    color: #64748B;
    font-size: 13px;
    font-weight: 700;
}

body:not(.colmena-login-page) .colmena-public-announcement-meta i {
    color: #124A9C;
}

body:not(.colmena-login-page) .colmena-announcement-edit {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: #F8FAFC;
    border: 1px solid #D8E0EA;
    color: #06203F !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none !important;
}

body:not(.colmena-login-page) .colmena-public-announcement-card h2 {
    margin: 0 0 14px;
    color: #0F172A;
    font-size: 30px;
    line-height: 1.15;
    font-weight: 900;
    letter-spacing: -0.035em;
}

body:not(.colmena-login-page) .colmena-public-announcement-card h2 a {
    color: #0F172A !important;
    text-decoration: none !important;
}

body:not(.colmena-login-page) .colmena-public-announcement-card h2 a:hover {
    color: #124A9C !important;
}

body:not(.colmena-login-page) .colmena-public-announcement-content {
    margin-bottom: 18px;
    color: #334155;
    font-size: 15px;
    line-height: 1.7;
}

body:not(.colmena-login-page) .colmena-public-announcement-content p {
    margin-bottom: 12px;
}

body:not(.colmena-login-page) .colmena-public-readmore {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 15px;
    border-radius: 999px;
    background: #06203F;
    color: #FFFFFF !important;
    font-size: 13px;
    font-weight: 900;
    text-decoration: none !important;
}

body:not(.colmena-login-page) .colmena-public-readmore:hover {
    background: #0B2E59;
}

body:not(.colmena-login-page) .colmena-public-empty {
    padding: 48px 28px;
    border-radius: 26px;
    background: #FFFFFF;
    border: 1px solid #E6ECF3;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.07);
    text-align: center;
}

body:not(.colmena-login-page) .colmena-public-empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 18px;
    border-radius: 22px;
    background: #EAF2FF;
    color: #124A9C;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
}

body:not(.colmena-login-page) .colmena-public-empty h2 {
    margin: 0;
    color: #0F172A;
    font-size: 26px;
    font-weight: 900;
}

body:not(.colmena-login-page) .colmena-public-empty p {
    margin: 10px 0 0;
    color: #64748B;
    font-size: 15px;
}

body:not(.colmena-login-page) .colmena-public-pagination {
    margin-top: 24px;
}

body:not(.colmena-login-page) .colmena-public-pagination .pagination {
    justify-content: center;
}

body:not(.colmena-login-page) .colmena-public-pagination .page-link {
    border-radius: 12px !important;
    margin: 0 3px;
    color: #06203F;
    border-color: #D8E0EA;
    font-weight: 800;
}

body:not(.colmena-login-page) .colmena-public-pagination .page-item.active .page-link {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #FFFFFF !important;
}

/* Ocultar Powered by WHMCS/WHMCompleteSolution */
body:not(.colmena-login-page) .primary-content > p[style*="text-align:center"],
body:not(.colmena-login-page) p:has(a[href*="whmcs.com"]),
body:not(.colmena-login-page) p:has(a[href*="WHMCompleteSolution"]),
body:not(.colmena-login-page) p:has(a[href*="whmcompletesolution"]) {
    display: none !important;
}

@media (max-width: 767px) {
    body:not(.colmena-login-page) .colmena-public-announcements {
        padding: 0 6px;
    }

    body:not(.colmena-login-page) .colmena-public-hero h1 {
        font-size: 32px;
    }

    body:not(.colmena-login-page) .colmena-public-announcement-card {
        padding: 24px;
        border-radius: 22px;
    }

    body:not(.colmena-login-page) .colmena-public-announcement-card h2 {
        font-size: 24px;
    }

    body:not(.colmena-login-page) .colmena-public-announcement-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* ==========================================================
   Colmena - Layout público moderno para Anuncios
   URL: /announcements.php
   ========================================================== */

body:not(.colmena-login-page):has(.colmena-public-app) {
    background:
        radial-gradient(circle at 18% 8%, rgba(18, 74, 156, 0.08) 0, rgba(18, 74, 156, 0) 30%),
        radial-gradient(circle at 92% 18%, rgba(245, 180, 0, 0.15) 0, rgba(245, 180, 0, 0) 28%),
        linear-gradient(180deg, #F8FAFD 0%, #EFF4FA 100%) !important;
}

body:not(.colmena-login-page):has(.colmena-public-app) header#header,
body:not(.colmena-login-page):has(.colmena-public-app) .navbar-main,
body:not(.colmena-login-page):has(.colmena-public-app) .master-breadcrumb,
body:not(.colmena-login-page):has(.colmena-public-app) footer.footer,
body:not(.colmena-login-page):has(.colmena-public-app) .secondary-sidebar,
body:not(.colmena-login-page):has(.colmena-public-app) .sidebar,
body:not(.colmena-login-page):has(.colmena-public-app) .btn-return-to-admin {
    display: none !important;
}

body:not(.colmena-login-page):has(.colmena-public-app) section#main-body {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    min-height: 100vh;
}

body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row {
    margin: 0 !important;
    min-height: 100vh;
}

body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row > .primary-content,
body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row > .col-md-9,
body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row > .col-sm-9,
body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row > .col-lg-8,
body:not(.colmena-login-page):has(.colmena-public-app) section#main-body > .container > .row > .col-xl-9 {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    padding: 0 !important;
}

/* App shell */
.colmena-public-app {
    display: flex;
    min-height: 100vh;
    color: #0F172A;
}

/* Sidebar */
.colmena-public-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 248px;
    height: 100vh;
    background: #FFFFFF;
    border-right: 1px solid #E6ECF3;
    box-shadow: 18px 0 45px rgba(15, 23, 42, 0.045);
    z-index: 1000;
    display: flex;
    flex-direction: column;
}

.colmena-public-logo {
    height: 94px;
    display: flex;
    align-items: center;
    padding: 0 26px;
    border-bottom: 1px solid #EEF2F7;
}

.colmena-public-logo img {
    max-width: 170px;
    height: auto;
    display: block;
}

.colmena-public-nav {
    padding: 22px 14px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.colmena-public-nav-item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 48px;
    padding: 0 14px;
    border-radius: 16px;
    color: #334155 !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 850;
    transition: all .18s ease;
}

.colmena-public-nav-item i {
    width: 22px;
    text-align: center;
    color: #124A9C;
    font-size: 16px;
}

.colmena-public-nav-item:hover {
    background: #F1F6FF;
    color: #06203F !important;
    transform: translateX(2px);
}

.colmena-public-nav-item.active {
    background: #06203F;
    color: #FFFFFF !important;
    box-shadow: 0 14px 28px rgba(6, 32, 63, 0.18);
}

.colmena-public-nav-item.active i {
    color: #FFFFFF;
}

.colmena-public-nav-item.active:before {
    content: "";
    position: absolute;
    left: -14px;
    top: 11px;
    width: 4px;
    height: 26px;
    border-radius: 999px;
    background: #F5B400;
}

.colmena-public-sidebar-footer {
    margin-top: auto;
    padding: 16px 14px 22px;
    border-top: 1px solid #EEF2F7;
}

/* Main */
.colmena-public-main {
    flex: 1;
    min-width: 0;
    margin-left: 248px;
}

/* Topbar */
.colmena-public-topbar {
    position: fixed;
    top: 0;
    left: 248px;
    right: 0;
    height: 76px;
    background: rgba(255,255,255,0.88);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(226, 232, 240, 0.85);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.055);
    z-index: 999;
    display: flex;
    align-items: center;
    padding: 0 34px;
    gap: 24px;
}

.colmena-public-topbar-title {
    flex: 0 0 auto;
}

.colmena-public-topbar-title span {
    color: #64748B;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.colmena-public-topnav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex: 1 1 auto;
}

.colmena-public-topnav a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 15px;
    border-radius: 999px;
    color: #475569 !important;
    font-size: 13px;
    font-weight: 850;
    text-decoration: none !important;
    transition: all .18s ease;
}

.colmena-public-topnav a:hover {
    background: #EEF5FF;
    color: #06203F !important;
}

.colmena-public-topnav a.active {
    background: #06203F;
    color: #FFFFFF !important;
    box-shadow: 0 12px 24px rgba(6, 32, 63, 0.18);
}

.colmena-public-topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
}

.colmena-public-ticket-btn,
.colmena-public-login-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 900;
    text-decoration: none !important;
}

.colmena-public-ticket-btn {
    background: #06203F;
    color: #FFFFFF !important;
    box-shadow: 0 12px 24px rgba(6, 32, 63, 0.18);
}

.colmena-public-login-btn {
    background: #FFFFFF;
    border: 1px solid #D8E0EA;
    color: #06203F !important;
}

/* Content */
.colmena-public-content {
    padding: 146px 36px 72px;
}

.colmena-public-card-shell {
    max-width: 1180px;
    margin: 0 auto;
    padding: 42px 46px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 96% 0%, rgba(18, 74, 156, 0.14) 0, rgba(18, 74, 156, 0) 24%),
        radial-gradient(circle at 4% 100%, rgba(245, 180, 0, 0.16) 0, rgba(245, 180, 0, 0) 28%),
        rgba(255,255,255,0.86);
    border: 1px solid rgba(226, 232, 240, 0.92);
    box-shadow: 0 30px 80px rgba(15, 23, 42, 0.09);
}

/* Hero */
.colmena-public-hero {
    margin-bottom: 28px;
}

.colmena-public-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 30px;
    padding: 0 13px;
    margin-bottom: 14px;
    border-radius: 999px;
    background: #EAF2FF;
    color: #124A9C;
    border: 1px solid rgba(18, 74, 156, 0.08);
    font-size: 12px;
    font-weight: 900;
}

.colmena-public-hero h1 {
    margin: 0;
    color: #0F172A;
    font-size: 42px;
    line-height: 1.05;
    font-weight: 950;
    letter-spacing: -0.055em;
}

.colmena-public-hero p {
    max-width: 660px;
    margin: 13px 0 0;
    color: #64748B;
    font-size: 15px;
    line-height: 1.7;
}

/* Announcements */
.colmena-announcements-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}

.colmena-public-announcement-card {
    position: relative;
    padding: 28px;
    border-radius: 26px;
    background: rgba(255,255,255,0.94);
    border: 1px solid rgba(226, 232, 240, 0.95);
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.070);
    overflow: hidden;
}

.colmena-public-announcement-card:before {
    content: "";
    position: absolute;
    left: 0;
    top: 28px;
    bottom: 28px;
    width: 5px;
    border-radius: 0 999px 999px 0;
    background: #124A9C;
}

.colmena-public-announcement-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
    color: #64748B;
    font-size: 13px;
    font-weight: 800;
}

.colmena-public-announcement-meta i {
    color: #124A9C;
}

.colmena-announcement-edit {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #F8FAFC;
    border: 1px solid #D8E0EA;
    color: #06203F !important;
    font-size: 12px;
    font-weight: 900;
    text-decoration: none !important;
}

.colmena-public-announcement-card h2 {
    margin: 0 0 14px;
    color: #0F172A;
    font-size: 30px;
    line-height: 1.15;
    font-weight: 950;
    letter-spacing: -0.04em;
}

.colmena-public-announcement-card h2 a {
    color: #0F172A !important;
    text-decoration: none !important;
}

.colmena-public-announcement-card h2 a:hover {
    color: #124A9C !important;
}

.colmena-public-announcement-content {
    margin-bottom: 20px;
    color: #334155;
    font-size: 15px;
    line-height: 1.72;
}

.colmena-public-announcement-content p {
    margin-bottom: 12px;
}

.colmena-public-readmore {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: #06203F;
    color: #FFFFFF !important;
    font-size: 13px;
    font-weight: 950;
    text-decoration: none !important;
    box-shadow: 0 12px 24px rgba(6, 32, 63, 0.18);
}

.colmena-public-readmore:hover {
    background: #0B2E59;
}

.colmena-public-empty {
    padding: 48px 28px;
    border-radius: 26px;
    background: #FFFFFF;
    border: 1px solid #E6ECF3;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.07);
    text-align: center;
}

.colmena-public-empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 18px;
    border-radius: 22px;
    background: #EAF2FF;
    color: #124A9C;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
}

.colmena-public-empty h2 {
    margin: 0;
    color: #0F172A;
    font-size: 26px;
    font-weight: 950;
}

.colmena-public-empty p {
    margin: 10px 0 0;
    color: #64748B;
    font-size: 15px;
}

/* Pagination */
.colmena-public-pagination {
    margin-top: 24px;
}

.colmena-public-pagination .pagination {
    justify-content: center;
}

.colmena-public-pagination .page-link {
    border-radius: 12px !important;
    margin: 0 3px;
    color: #06203F;
    border-color: #D8E0EA;
    font-weight: 800;
}

.colmena-public-pagination .page-item.active .page-link {
    background: #06203F !important;
    border-color: #06203F !important;
    color: #FFFFFF !important;
}

/* Limpieza */
body:not(.colmena-login-page):has(.colmena-public-app) .primary-content > p[style*="text-align:center"],
body:not(.colmena-login-page):has(.colmena-public-app) p:has(a[href*="whmcs.com"]),
body:not(.colmena-login-page):has(.colmena-public-app) p:has(a[href*="WHMCompleteSolution"]),
body:not(.colmena-login-page):has(.colmena-public-app) p:has(a[href*="whmcompletesolution"]) {
    display: none !important;
}

/* Responsive */
@media (max-width: 1199px) {
    .colmena-public-topnav {
        display: none;
    }
}

@media (max-width: 991px) {
    .colmena-public-sidebar {
        display: none;
    }

    .colmena-public-main {
        margin-left: 0;
    }

    .colmena-public-topbar {
        left: 0;
        padding: 0 18px;
    }

    .colmena-public-topbar-title {
        display: none;
    }

    .colmena-public-topbar-actions {
        margin-left: auto;
    }

    .colmena-public-content {
        padding: 110px 18px 48px;
    }

    .colmena-public-card-shell {
        padding: 30px 24px;
        border-radius: 26px;
    }
}

@media (max-width: 575px) {
    .colmena-public-topbar {
        height: 72px;
    }

    .colmena-public-ticket-btn {
        display: none;
    }

    .colmena-public-content {
        padding: 96px 14px 40px;
    }

    .colmena-public-card-shell {
        padding: 26px 18px;
        border-radius: 24px;
    }

    .colmena-public-hero h1 {
        font-size: 34px;
    }

    .colmena-public-announcement-card {
        padding: 24px;
        border-radius: 22px;
    }

    .colmena-public-announcement-card h2 {
        font-size: 24px;
    }

    .colmena-public-announcement-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}


/* ==========================================================
   Colmena - Login novedades mejoradas
   Separación + alerta naranja + scroll vertical
   ========================================================== */

body.colmena-login-page .colmena-login-side-copy {
    top: 37% !important;
}

body.colmena-login-page .colmena-login-announcements {
    position: fixed;
    left: 5.5%;
    top: 70%;
    width: 33%;
    max-width: 540px;
    z-index: 3;
}

body.colmena-login-page .colmena-login-announcements-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

body.colmena-login-page .colmena-login-announcements-header span {
    color: rgba(255,255,255,0.82);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.colmena-login-page .colmena-login-announcements-header a {
    color: rgba(255,255,255,0.88) !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

body.colmena-login-page .colmena-login-announcements-header a:hover {
    color: #ffffff !important;
    text-decoration: underline;
}

body.colmena-login-page .colmena-login-announcements-slider {
    max-height: 124px;
    overflow-y: auto;
    padding-right: 6px;
    scroll-behavior: smooth;
}

body.colmena-login-page .colmena-login-announcements-slider::-webkit-scrollbar {
    width: 5px;
}

body.colmena-login-page .colmena-login-announcements-slider::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.08);
    border-radius: 999px;
}

body.colmena-login-page .colmena-login-announcements-slider::-webkit-scrollbar-thumb {
    background: rgba(245, 180, 0, 0.75);
    border-radius: 999px;
}

body.colmena-login-page .colmena-login-announcement-item {
    display: block;
    min-height: 106px;
    padding: 15px 17px;
    margin-bottom: 10px;
    border-radius: 17px;
    background:
        linear-gradient(135deg, rgba(255, 247, 230, 0.18) 0%, rgba(245, 180, 0, 0.12) 100%);
    border: 1px solid rgba(245, 180, 0, 0.48);
    color: #ffffff !important;
    text-decoration: none !important;
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.12);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: all .18s ease;
    position: relative;
    overflow: hidden;
}

body.colmena-login-page .colmena-login-announcement-item:before {
    content: "";
    position: absolute;
    left: 0;
    top: 14px;
    bottom: 14px;
    width: 4px;
    border-radius: 0 999px 999px 0;
    background: #F5B400;
}

body.colmena-login-page .colmena-login-announcement-item:hover {
    background:
        linear-gradient(135deg, rgba(255, 247, 230, 0.24) 0%, rgba(245, 180, 0, 0.18) 100%);
    border-color: rgba(245, 180, 0, 0.70);
    transform: translateY(-1px);
}

body.colmena-login-page .colmena-login-announcement-item small {
    display: block;
    margin-bottom: 7px;
    color: rgba(255,255,255,0.72);
    font-size: 11px;
    font-weight: 700;
}

body.colmena-login-page .colmena-login-announcement-item strong {
    display: block;
    color: #ffffff;
    font-size: 14px;
    line-height: 1.35;
    font-weight: 900;
}

body.colmena-login-page .colmena-login-announcement-item p {
    margin: 7px 0 0;
    color: rgba(255,255,255,0.82);
    font-size: 12px;
    line-height: 1.45;
    font-weight: 500;
}

@media (max-width: 991px) {
    body.colmena-login-page .colmena-login-announcements {
        display: none !important;
    }
}

/* ==========================================================
   Colmena - Animación visible para slider de novedades
   ========================================================== */

body.colmena-login-page .colmena-login-announcement-item {
    opacity: 0.72;
    transform: scale(0.985);
}

body.colmena-login-page .colmena-login-announcement-item.is-active {
    opacity: 1;
    transform: scale(1);
    border-color: rgba(245, 180, 0, 0.78);
    box-shadow:
        0 16px 34px rgba(0, 0, 0, 0.16),
        0 0 0 1px rgba(245, 180, 0, 0.18);
}

body.colmena-login-page .colmena-login-announcement-item.is-changing {
    animation: colmenaAnnouncementChange .42s ease both;
}

@keyframes colmenaAnnouncementChange {
    0% {
        opacity: 0.35;
        transform: translateY(10px) scale(0.97);
    }

    60% {
        opacity: 1;
        transform: translateY(-2px) scale(1.01);
    }

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