@import url('rh-components.css');
@import url('saas.css');

:root {
    --rh-navy: #1a3461;
    --rh-navy-dark: #111e3d;
    --rh-navy-mid: #1e3f78;
    --rh-teal: #2dc4b4;
    --rh-teal-dark: #1fa898;
    --rh-sidebar: var(--rh-navy);
    --rh-sidebar-dark: var(--rh-navy-dark);
    --rh-sidebar-w: 252px;
    --bs-primary: var(--rh-navy);
    --bs-info: var(--rh-teal);
}

body { font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; }
.text-navy { color: var(--rh-navy) !important; }
.text-teal { color: var(--rh-teal) !important; }
.bg-navy { background: var(--rh-navy) !important; }

.admin-body { min-height: 100vh; background: #f4f7fb; }
.sidebar {
    width: var(--rh-sidebar-w);
    background: linear-gradient(180deg, var(--rh-sidebar-dark, var(--rh-navy-dark)) 0%, var(--rh-sidebar, var(--rh-navy)) 100%);
    color: #fff;
}
.sidebar-nav-scroll {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    gap: .25rem;
    padding: .75rem;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.sidebar-nav-scroll::-webkit-scrollbar { display: none; }
.sidebar-nav-footer {
    margin-top: .35rem;
    padding-top: .15rem;
}
.sidebar-nav-footer .sidebar-divider { margin-top: 0; }
.sidebar .nav-link { color: rgba(255,255,255,.82); border-radius: .5rem; display: flex; align-items: center; gap: .5rem; font-size: .9rem; padding: .5rem .75rem; text-decoration: none; width: 100%; max-width: 100%; box-sizing: border-box; }
.sidebar-menu-group { margin: 0; border: 0; width: 100%; max-width: 100%; flex-shrink: 0; }
.sidebar-menu-group__summary {
    list-style: none;
    cursor: pointer;
    user-select: none;
    color: rgba(255,255,255,.82);
    border-radius: .5rem;
    padding: .5rem .75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    font-size: .9rem;
}
.sidebar-menu-group__summary::-webkit-details-marker { display: none; }
.sidebar-menu-group__summary:hover,
.sidebar-menu-group[open] > .sidebar-menu-group__summary { background: rgba(255,255,255,.12); color: #fff; }
.sidebar-menu-group__label { display: inline-flex; align-items: center; gap: .5rem; min-width: 0; }
.sidebar-menu-group__chev { font-size: .75rem; opacity: .7; transition: transform .2s ease; flex-shrink: 0; }
.sidebar-menu-group[open] .sidebar-menu-group__chev { transform: rotate(180deg); }
.sidebar-menu-group__items {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    padding: .25rem 0 .35rem .35rem;
    margin-left: .65rem;
    border-left: 1px solid rgba(255,255,255,.12);
    overflow: visible;
}
.sidebar-menu-group__link {
    display: block;
    color: rgba(255,255,255,.72);
    text-decoration: none;
    font-size: .8rem;
    padding: .3rem .65rem;
    border-radius: .4rem;
    line-height: 1.3;
}
.sidebar-menu-group__link:hover,
.sidebar-menu-group__link.active { background: rgba(255,255,255,.1); color: #fff; }
.sidebar-brand { display: block; padding: 1.25rem 1rem; text-align: center; flex-shrink: 0; }
.sidebar-logo { max-height: 3rem; max-width: 180px; object-fit: contain; background: #fff; border-radius: .75rem; padding: .5rem; }
.sidebar-logo--tenant { background: transparent; padding: 0; filter: drop-shadow(0 1px 3px rgba(0,0,0,.35)); }
.sidebar .nav-link:hover, .sidebar .nav-link.active { background: rgba(255,255,255,.12); color: #fff; }
.sidebar-divider { border-top: 1px solid rgba(255,255,255,.12); margin: .5rem 0; width: 100%; flex-shrink: 0; }
.admin-main { flex: 1; min-width: 0; min-height: 100vh; display: flex; flex-direction: column; }
.admin-topbar { background: #fff; border-bottom: 1px solid #e2e8f0; padding: .85rem 1.25rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.admin-topbar__lead {
    display: flex;
    align-items: center;
    gap: .85rem;
    min-width: 0;
    flex: 1 1 auto;
}
.admin-topbar__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: .35rem .65rem;
    min-width: 0;
    padding-left: .85rem;
    border-left: 2px solid #e8edf3;
}
.admin-topbar__date {
    font-size: .75rem;
    color: #64748b;
    text-transform: capitalize;
    white-space: nowrap;
}
.admin-topbar__datetime {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    white-space: nowrap;
}
.admin-topbar__datetime .admin-topbar__date::after {
    content: '·';
    margin-left: .4rem;
    color: #94a3b8;
    text-transform: none;
}
.admin-topbar__clock {
    font-size: .75rem;
    font-weight: 600;
    color: var(--rh-navy);
    font-variant-numeric: tabular-nums;
    letter-spacing: .02em;
}
.admin-topbar__legal {
    font-size: .68rem;
    color: #94a3b8;
    letter-spacing: .01em;
}
.admin-topbar__greeting {
    font-size: .88rem;
    font-weight: 600;
    color: var(--rh-navy);
    white-space: nowrap;
}
.admin-topbar__subtitle {
    font-size: .78rem;
    color: #64748b;
}
.admin-topbar__subtitle strong { color: var(--rh-navy); font-weight: 600; }
.dash-chart-badge {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: .5rem;
    padding: .4rem .75rem;
    border-radius: .5rem;
    background: rgba(45, 196, 180, 0.15);
    border: 1px solid rgba(45, 196, 180, 0.35);
    color: var(--rh-navy);
    box-shadow: none;
    flex-shrink: 0;
}
.dash-chart-badge__label {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1;
}
.dash-chart-badge__value {
    font-size: .95rem;
    font-weight: 700;
    line-height: 1;
}
.dash-chart-badge__detail {
    font-size: .75rem;
    opacity: .85;
    line-height: 1;
}
.admin-content { padding: 1.25rem; flex: 1; }
.dash-card { background: #fff; border-radius: .85rem; border: 1px solid #e8edf3; box-shadow: 0 1px 3px rgba(15,23,42,.04); }

.btn-primary { background: var(--rh-navy); border-color: var(--rh-navy); }
.btn-primary:hover { background: var(--rh-navy-dark); border-color: var(--rh-navy-dark); }
.btn-success, .btn-info { background: var(--rh-teal); border-color: var(--rh-teal); }

.authentication-card { width: 100%; max-width: 420px; margin: 2rem; padding: 2rem; border-radius: 1rem; background: rgba(17,30,61,.72); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); color: #fff; }

/* ── Login / Auth (cores do tema do tenant) ── */
.auth-overlay {
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--rh-navy-dark, #111e3d) 55%, transparent),
        color-mix(in srgb, var(--rh-navy, #1a3461) 35%, transparent)
    );
}
.auth-card {
    border-color: color-mix(in srgb, var(--rh-teal, #2dc4b4) 22%, rgba(255,255,255,.15)) !important;
    box-shadow:
        0 25px 60px color-mix(in srgb, var(--rh-navy-dark, #111e3d) 45%, transparent),
        inset 0 1px 0 rgba(255,255,255,.08),
        0 0 0 1px color-mix(in srgb, var(--rh-teal, #2dc4b4) 12%, transparent) !important;
}
.auth-input {
    width: 100%;
    padding: .875rem 1rem .875rem 2.75rem;
    background: #fff;
    border-radius: .75rem;
    border: 0;
    font-size: .875rem;
    color: #1e293b;
    box-shadow: 0 1px 2px rgba(15,23,42,.06);
}
.auth-input::placeholder { color: #94a3b8; }
.auth-input:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--rh-teal, #2dc4b4);
}
.auth-btn {
    width: 100%;
    padding: 1rem;
    margin-top: .5rem;
    background: var(--rh-navy, #1a3461);
    color: #fff;
    font-weight: 700;
    font-size: .875rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    border: 0;
    border-radius: .75rem;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--rh-navy-dark, #111e3d) 35%, transparent);
    transition: background .2s, transform .15s;
    cursor: pointer;
}
.auth-btn:hover { background: var(--rh-navy-dark, #111e3d); }
.auth-btn:active { transform: scale(.98); }
.auth-link {
    color: var(--rh-teal, #2dc4b4);
    font-weight: 600;
    text-decoration: none;
    transition: color .15s;
}
.auth-link:hover { color: var(--rh-teal-dark, #1fa898); }
.auth-checkbox {
    width: 1rem;
    height: 1rem;
    accent-color: var(--rh-teal, #2dc4b4);
    cursor: pointer;
}

.branding-preview-sidebar { min-height: 72px; }
.branding-preview-login { border: 1px solid #e2e8f0; }

/* ── Cards do dashboard ── */
.dash-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .5rem;
    padding: .9rem 1.25rem;
    border-bottom: 1px solid #e8edf3;
    font-weight: 700;
    font-size: .92rem;
    color: var(--rh-navy);
    background: linear-gradient(180deg, #fafbfd, #fff);
}
.dash-card__body { padding: 1.25rem; }

.dash-table-head th {
    background: var(--rh-navy);
    color: #fff;
    font-size: .78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    border: none;
    padding: .75rem 1rem;
    white-space: nowrap;
}
.dash-table-head th:first-child { border-radius: 0; }

/* ── Relógios Control iD ── */
.clocks-layout {
    display: grid;
    gap: 1.25rem;
    align-items: start;
}
.clocks-layout__devices,
.clocks-layout__history {
    min-width: 0;
}
@media (min-width: 1200px) {
    .clocks-layout {
        grid-template-columns: minmax(0, 1.7fr) minmax(280px, 1fr);
    }
}
.clocks-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.clocks-table tbody tr {
    position: relative;
}
.clocks-actions .dropdown-menu {
    z-index: 1080;
}
.clocks-table {
    width: 100%;
    min-width: 720px;
}
.clocks-table th,
.clocks-table td {
    vertical-align: middle;
}
.clocks-table th:first-child,
.clocks-table td:first-child {
    padding-left: 1rem;
}
.clocks-table__name {
    max-width: 14rem;
}
.clocks-device-name {
    font-size: .82rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--rh-navy);
    word-break: break-word;
}
.clocks-device-meta {
    font-size: .78rem;
    line-height: 1.35;
    color: #64748b;
}
.clocks-table th:last-child,
.clocks-table td:last-child {
    padding-right: 1rem;
}
.clocks-actions {
    display: inline-flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: .25rem;
}
.clocks-actions .btn {
    padding: .25rem .45rem;
}
.clocks-status {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
}
.clocks-status-label {
    font-size: .8125rem;
    font-weight: 600;
    line-height: 1;
}
.clocks-status-label--ok {
    color: #198754;
}
.clocks-status-label--fail,
.clocks-status-label--inactive {
    color: #dc3545;
}
.clocks-status-label--warn,
.clocks-status-label--testing {
    color: #ca8a04;
}
.clocks-status-label--unknown,
.clocks-status-label--idle {
    color: #64748b;
}
.clocks-conn-dot {
    width: .65rem;
    height: .65rem;
    padding: 0;
    border: 0;
    border-radius: 50%;
    flex-shrink: 0;
    cursor: pointer;
    transition: background-color .2s, box-shadow .2s, transform .15s;
}
.clocks-conn-dot:hover {
    transform: scale(1.15);
}
.clocks-conn-dot--idle,
.clocks-conn-dot--unknown {
    background: #cbd5e1;
}
.clocks-conn-dot--inactive {
    background: #94a3b8;
}
.clocks-conn-dot--testing {
    background: #ca8a04;
    animation: clocks-conn-pulse 1s ease-in-out infinite;
}
.clocks-conn-dot--ok {
    background: #198754;
    box-shadow: 0 0 0 2px rgba(25, 135, 84, .2);
}
.clocks-conn-dot--warn {
    background: #ca8a04;
    box-shadow: 0 0 0 2px rgba(202, 138, 4, .2);
}
.clocks-conn-dot--fail {
    background: #dc3545;
    box-shadow: 0 0 0 2px rgba(220, 53, 69, .2);
}
@keyframes clocks-conn-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .45; }
}
.clocks-history {
    max-height: min(520px, 70vh);
    overflow-y: auto;
}
.clocks-history__item {
    padding: .75rem 1rem;
    border: 0;
    border-bottom: 1px solid #eef2f7;
}
.clocks-history__item:last-child {
    border-bottom: 0;
}
.clocks-history__msg {
    font-size: .78rem;
    line-height: 1.35;
    word-break: break-word;
}
.clocks-history__meta {
    font-size: .72rem;
    gap: .5rem;
}

/* Modais cadastro/edição de dispositivos */
.clocks-device-modal {
    max-width: min(920px, calc(100vw - 2rem));
    margin: 1rem auto;
}
.clocks-device-modal .modal-content {
    max-height: calc(100vh - 2rem);
    display: flex;
    flex-direction: column;
}
.clocks-device-modal .modal-body {
    overflow-y: auto;
    flex: 1 1 auto;
}
.clocks-device-modal__body {
    padding: 1.25rem 1.5rem;
}
.clocks-device-section {
    border: 1px solid #e8edf3;
    border-radius: .75rem;
    padding: 1rem 1.1rem;
    background: #f8fafc;
}
.clocks-device-section__title {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: .85rem;
}
#createClockModal .form-select,
#editClockModal .form-select,
#createClockModal .form-control,
#editClockModal .form-control {
    font-size: .92rem;
}
#createClockModal .modal-footer,
#editClockModal .modal-footer {
    padding: .9rem 1.5rem;
    background: #fff;
    border-top: 1px solid #e8edf3;
}

/* Mobile — relógios em cards */
@media (max-width: 767.98px) {
    .clocks-page-header {
        flex-direction: column;
        align-items: stretch !important;
        gap: .75rem !important;
        margin-bottom: 1rem !important;
    }
    .clocks-page-header__title h4 {
        font-size: 1.05rem;
    }
    .clocks-page-header__btn {
        width: 100%;
    }

    .clocks-layout {
        gap: 1rem;
    }
    .clocks-layout__devices .dash-card__header,
    .clocks-layout__history .dash-card__header {
        padding: .65rem .85rem !important;
    }

    .clocks-table-wrap {
        overflow-x: visible;
    }
    .clocks-table {
        min-width: 0;
    }
    .clocks-table thead {
        display: none;
    }
    .clocks-table tbody tr {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "name status"
            "name actions";
        gap: .35rem .75rem;
        padding: .875rem 1rem;
        border-bottom: 1px solid #eef2f7;
        align-items: start;
        overflow: visible;
    }
    .clocks-table tbody tr:last-child {
        border-bottom: 0;
    }
    .clocks-table tbody tr:hover {
        background: #f8fafc;
    }
    .clocks-table td {
        display: block;
        padding: 0 !important;
        border: 0;
        background: transparent !important;
    }
    .clocks-table td:first-child,
    .clocks-table td:last-child {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .clocks-table td.d-none {
        display: none !important;
    }
    .clocks-table__name {
        grid-area: name;
        max-width: none;
        min-width: 0;
        align-self: center;
    }
    .clocks-table__status {
        grid-area: status;
        justify-self: end;
        align-self: start;
    }
    .clocks-table__actions {
        grid-area: actions;
        justify-self: end;
        align-self: start;
        text-align: right !important;
        overflow: visible;
    }
    .clocks-actions,
    .clocks-actions .dropdown {
        overflow: visible;
    }
    .clocks-device-name {
        font-size: .875rem;
        padding-right: .25rem;
    }
    .clocks-device-meta--mobile {
        margin-top: .2rem;
        font-size: .72rem;
    }
    .clocks-actions {
        width: auto;
        justify-content: flex-end;
        gap: .35rem;
        padding-top: 0;
        border-top: 0;
    }
    .clocks-actions .btn {
        min-width: 2.25rem;
        min-height: 2.25rem;
        padding: .35rem .55rem;
    }
    .clocks-status {
        white-space: nowrap;
    }

    .clocks-history {
        max-height: none;
    }
    .clocks-history__item {
        padding: .75rem .85rem;
    }
    .clocks-history__msg {
        font-size: .78rem;
        -webkit-line-clamp: 3;
    }
    .clocks-history__meta {
        flex-direction: column;
        align-items: flex-start !important;
        gap: .15rem;
    }
    .clocks-history__meta span:last-child {
        font-size: .7rem;
    }

    #createClockModal .modal-dialog,
    #editClockModal .modal-dialog {
        margin: .5rem auto;
        max-width: calc(100% - 1rem);
    }
    .clocks-device-modal__body {
        padding: 1rem;
    }
    .clocks-device-section {
        padding: .85rem;
    }
    #createClockModal .row .col-8,
    #createClockModal .row .col-4,
    #createClockModal .row .col-6,
    #editClockModal .row .col-8,
    #editClockModal .row .col-4,
    #editClockModal .row .col-6 {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* ── Espelho de ponto: cabeçalhos compactos dos 4 slots ── */
.ponto-slot-th {
    min-width: 4.1rem;
    max-width: 4.75rem;
    padding: .55rem .3rem !important;
    vertical-align: bottom;
}
.ponto-slot-stack {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    line-height: 1.1;
    gap: .05rem;
}
.ponto-slot-line {
    font-size: .7rem;
    letter-spacing: .03em;
}
.ponto-slot-sub {
    font-size: .6rem;
    font-weight: 500;
    opacity: .78;
    text-transform: lowercase;
    letter-spacing: 0;
}

/* ── Stat cards ── */
.stat-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: #fff;
    border: 1px solid #e8edf3;
    border-radius: .85rem;
    padding: 1.1rem 1.25rem;
    box-shadow: 0 1px 3px rgba(15, 23, 42, .04);
    height: 100%;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.stat-card__icon {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: .75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    flex-shrink: 0;
}
.stat-card__label {
    font-size: .78rem;
    color: #64748b;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.stat-card__value {
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--rh-navy);
    line-height: 1.1;
}
.stat-card__meta {
    font-size: .72rem;
    color: #94a3b8;
    margin-top: .15rem;
    line-height: 1.35;
}
.stat-card__body {
    flex: 1;
    min-width: 0;
}
.stat-card__main {
    flex: 1;
    min-width: 0;
    position: relative;
}
.stat-card--employees .stat-card__watermark {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    pointer-events: none;
    user-select: none;
    line-height: 1;
    opacity: .12;
    z-index: 0;
}
.stat-card--employees .stat-card__watermark strong {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--rh-navy);
    letter-spacing: -.02em;
    line-height: 1;
}
.stat-card--employees .stat-card__watermark span {
    display: block;
    margin-top: .08rem;
    font-size: .5rem;
    font-weight: 600;
    color: var(--rh-navy);
    text-transform: uppercase;
    letter-spacing: .06em;
}
.stat-card--employees .stat-card__label,
.stat-card--employees .stat-card__value,
.stat-card--employees .stat-card__meta {
    position: relative;
    z-index: 1;
}
.stat-card__dual {
    display: flex;
    align-items: flex-end;
    gap: 1.25rem;
    margin-top: .15rem;
}
.stat-card__dual-item strong {
    display: block;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--rh-navy);
    line-height: 1.1;
}
.stat-card__dual-item span {
    display: block;
    font-size: .68rem;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-top: .1rem;
}
.stat-card__substats {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem .65rem;
    margin-top: .45rem;
    font-size: .72rem;
    color: #94a3b8;
}
.stat-card__substats a {
    color: var(--rh-teal);
    text-decoration: none;
}
.stat-card__substats a:hover { text-decoration: underline; }
.stat-card__content-link {
    display: block;
    text-decoration: none;
    color: inherit;
}
.stat-card__content-link:hover { color: inherit; }
.stat-card__icon-link {
    text-decoration: none;
    color: inherit;
    flex-shrink: 0;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: .75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
}
.stat-card__icon-link:hover { color: inherit; }
a.stat-card,
a.dash-mini-kpi {
    text-decoration: none;
    color: inherit;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
a.stat-card:hover,
a.dash-mini-kpi:hover,
.stat-card:hover {
    border-color: rgba(45, 196, 180, .45);
    box-shadow: 0 4px 14px rgba(15, 23, 42, .08);
    transform: translateY(-1px);
    color: inherit;
}
.dash-card__nav-link {
    font-size: .78rem;
    font-weight: 600;
    color: var(--rh-teal);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}
.dash-card__nav-link:hover { color: var(--rh-teal-dark, #1fa89a); }
.dash-card__title-link {
    color: inherit;
    text-decoration: none;
    min-width: 0;
    flex: 1 1 auto;
}
.dash-card__title-link:hover { color: var(--rh-navy); }

.dash-mini-kpi-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px) {
    .dash-mini-kpi-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1200px) {
    .dash-mini-kpi-grid { grid-template-columns: repeat(5, 1fr); }
}

/* ── Tenant Dashboard Premium ── */
.dash-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.5rem 1.75rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, var(--rh-navy) 0%, var(--rh-navy-mid) 55%, var(--rh-teal-dark) 100%);
    color: #fff;
    box-shadow: 0 12px 32px rgba(26, 52, 97, .18);
}
.dash-hero__eyebrow {
    font-size: .82rem;
    opacity: .85;
    margin-bottom: .35rem;
    text-transform: capitalize;
}
.dash-hero__title {
    font-size: clamp(1.35rem, 2.5vw, 1.85rem);
    font-weight: 700;
    margin-bottom: .35rem;
}
.dash-hero__subtitle {
    font-size: .92rem;
    opacity: .9;
}
.dash-hero__badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 8.5rem;
    padding: .85rem 1.25rem;
    border-radius: .85rem;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
    backdrop-filter: blur(6px);
    text-align: center;
}
.dash-hero__badge-label {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    opacity: .85;
}
.dash-hero__badge-value {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1.1;
}
.dash-hero__badge-detail {
    opacity: .85;
    font-size: .78rem;
}

@media (max-width: 767.98px) {
    .admin-content { padding: .75rem; }
    .admin-topbar { padding: .65rem .75rem; gap: .5rem; }
    .admin-topbar__lead { flex-wrap: nowrap; gap: .45rem; min-width: 0; }
    .admin-topbar h5 { font-size: .95rem; flex-shrink: 0; }
    .admin-topbar__meta {
        flex: 0 1 auto;
        flex-basis: auto;
        padding-left: .45rem;
        border-left: 1px solid #e8edf3;
        padding-top: 0;
        gap: .2rem .35rem;
        min-width: 0;
        overflow: hidden;
    }
    .admin-topbar__datetime { gap: .25rem; min-width: 0; }
    .admin-topbar__date { font-size: .7rem; }
    .admin-topbar__datetime .admin-topbar__date::after { margin-left: .25rem; }
    .admin-topbar__clock { font-size: .7rem; }
    .admin-topbar__greeting { font-size: .82rem; }

    .dash-chart-badge {
        gap: .35rem;
        padding: .35rem .6rem;
    }
    .dash-chart-badge__value { font-size: .85rem; }
    .dash-chart-badge__detail { font-size: .7rem; }

    .stat-card {
        padding: .65rem .75rem;
        gap: .55rem;
    }
    .stat-card__icon,
    .stat-card__icon-link {
        width: 2.1rem;
        height: 2.1rem;
        font-size: 1rem;
    }
    .stat-card__label { font-size: .68rem; }
    .stat-card__value { font-size: 1.2rem; }
    .stat-card--employees .stat-card__watermark strong { font-size: 1.05rem; }
    .stat-card--employees .stat-card__watermark span { font-size: .42rem; }
    .stat-card__dual-item strong { font-size: 1.1rem; }
    .stat-card__dual-item span { font-size: .62rem; }
    .stat-card__substats { font-size: .65rem; margin-top: .3rem; }
    .stat-card__meta { display: none; }

    .dash-mini-kpi {
        padding: .55rem .65rem;
        gap: .5rem;
    }
    .dash-mini-kpi i { font-size: 1rem; }
    .dash-mini-kpi span { font-size: .62rem; }
    .dash-mini-kpi strong { font-size: .9rem; }

    .dash-chart-wrap { height: 170px; }
    .dash-chart-wrap--tall { height: 190px; }
    .dash-chart-wrap--month { height: 240px; }
    .dash-chart-wrap--scroll {
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .dash-chart-wrap--scroll canvas {
        min-width: 280px;
    }
    .dash-card--attendance .dash-card__header {
        align-items: flex-start;
        gap: .45rem;
    }
    .dash-card--attendance .dash-card__header > .d-flex {
        width: 100%;
        justify-content: space-between;
    }
    .dash-card--attendance .dash-card__title-link {
        font-size: .85rem;
        line-height: 1.25;
    }
    .dash-card--attendance .dash-insights {
        margin-top: .75rem;
        padding-top: .75rem;
    }
    .dash-card--attendance .dash-insights__legend {
        display: none;
    }
    .dash-card--attendance .dash-insights__item {
        font-size: .74rem;
        padding: .3rem .45rem;
    }
    .dash-card__header { padding: .65rem .85rem; font-size: .88rem; }
    .dash-card__body { padding: .85rem; }
    .dash-card--attendance .dash-card__body { padding: .65rem .75rem .75rem; }
}

@media (max-width: 575.98px) {
    .admin-topbar__lead { gap: .35rem; }
    .admin-topbar h5 { font-size: .88rem; }
    .admin-topbar__meta { padding-left: .35rem; }
    .admin-topbar__date,
    .admin-topbar__clock { font-size: .65rem; }
}

.dash-mini-kpi {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1rem;
    background: #fff;
    border: 1px solid #e8edf3;
    border-radius: .75rem;
    height: 100%;
    box-shadow: 0 1px 3px rgba(15, 23, 42, .04);
}
.dash-mini-kpi i { font-size: 1.25rem; flex-shrink: 0; }
.dash-mini-kpi span {
    display: block;
    font-size: .72rem;
    color: #64748b;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.dash-mini-kpi strong {
    display: block;
    font-size: 1.05rem;
    color: var(--rh-navy);
}
.dash-chart-wrap {
    position: relative;
    height: 220px;
}
.dash-chart-wrap--tall { height: 280px; }
.dash-chart-wrap--month { height: 220px; }

.dash-insights {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #eef2f7;
}
.dash-insights__title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--rh-navy);
    margin-bottom: .65rem;
}
.dash-insights__legend {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem .75rem;
    margin-bottom: .65rem;
}
.dash-insights__chip {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .72rem;
    color: #64748b;
}
.dash-insights__chip i { font-size: .45rem; }
.dash-insights__chip--normal i { color: var(--rh-teal); }
.dash-insights__chip--expected i { color: #94a3b8; }
.dash-insights__chip--anomaly i { color: #dc3545; }
.dash-insights__list {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}
.dash-insights__item {
    font-size: .8rem;
    color: #64748b;
    padding: .35rem .5rem;
    border-radius: .4rem;
    background: #f8fafc;
}
.dash-insights__item strong { color: var(--rh-navy); }
.dash-insights__item--expected_low { border-left: 3px solid #94a3b8; }
.dash-insights__item--anomaly { border-left: 3px solid #dc3545; background: rgba(220, 53, 69, .04); }
.dash-insights__item--normal { border-left: 3px solid var(--rh-teal); }
.dash-quick-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .65rem;
}
.dash-quick-link {
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .7rem .85rem;
    border-radius: .65rem;
    text-decoration: none;
    font-size: .84rem;
    font-weight: 600;
    border: 1px solid #e8edf3;
    background: #f8fafc;
    color: var(--rh-navy);
    transition: transform .15s, box-shadow .15s, background .15s;
}
.dash-quick-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(15, 23, 42, .08);
    color: var(--rh-navy);
}
.dash-quick-link--teal { border-color: rgba(45, 196, 180, .25); background: rgba(45, 196, 180, .08); }
.dash-quick-link--warning { border-color: rgba(202, 138, 4, .25); background: rgba(202, 138, 4, .08); }
.dash-quick-link--navy { border-color: rgba(26, 52, 97, .15); }
.dash-list-item {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .85rem 1.25rem;
    border-bottom: 1px solid #eef2f7;
}
.dash-list-item:last-child { border-bottom: 0; }
.dash-list-item__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: .55rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}
.dash-list-item__icon.is-ok { background: rgba(45, 196, 180, .15); color: var(--rh-teal); }
.dash-list-item__icon.is-warn { background: rgba(202, 138, 4, .15); color: #ca8a04; }
.dash-list-item__icon.is-danger { background: rgba(220, 53, 69, .12); color: #dc3545; }
.dash-list-item__icon.is-info { background: rgba(26, 52, 97, .1); color: var(--rh-navy); }
.dash-list-item__icon.is-off { background: #f1f5f9; color: #94a3b8; }
.dash-progress {
    height: .55rem;
    background: #e8edf3;
    border-radius: 999px;
    overflow: hidden;
}
.dash-progress__bar {
    height: 100%;
    background: linear-gradient(90deg, var(--rh-teal), var(--rh-navy));
    border-radius: 999px;
    transition: width .6s ease;
}


/* ── Info boxes (modais) ── */
.info-box {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: .65rem;
    padding: .75rem 1rem;
}
.info-box__label {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #94a3b8;
    margin-bottom: .15rem;
}
.info-box__value {
    font-size: .92rem;
    color: var(--rh-navy);
    word-break: break-word;
}

/* ── Badges de status / plano ── */
.badge-status {
    display: inline-block;
    padding: .22rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .02em;
}
.badge-status--ativo,
.badge-status--ativa { background: #ecfdf5; color: #047857; }
.badge-status--suspenso,
.badge-status--suspensa { background: #fffbeb; color: #b45309; }
.badge-status--inativo,
.badge-status--inativa { background: #fef2f2; color: #b91c1c; }
.badge-status--provisionando { background: #ede9fe; color: #6d28d9; }
.badge-status--trial { background: #fef9c3; color: #a16207; }
.badge-status--cancelado { background: #fee2e2; color: #dc2626; }

.badge-plano {
    display: inline-block;
    padding: .2rem .6rem;
    border-radius: .4rem;
    font-size: .75rem;
    font-weight: 600;
    background: #e6eef8;
    color: var(--rh-navy);
}

.status-dot {
    width: .55rem;
    height: .55rem;
    border-radius: 50%;
    flex-shrink: 0;
}
.status-dot--on {
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, .18);
}
.status-dot--off {
    background: #ef4444;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .18);
}

/* ── Seções de formulário ── */
.admin-section-title {
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--rh-navy);
    margin-bottom: .75rem;
}

/* ── Botões utilitários ── */
.btn-navy {
    background: var(--rh-navy) !important;
    border-color: var(--rh-navy) !important;
    color: #fff !important;
}
.btn-navy:hover {
    background: var(--rh-navy-dark) !important;
    border-color: var(--rh-navy-dark) !important;
}
.btn-navy:disabled,
.btn-primary.btn-navy:disabled {
    background: var(--rh-navy) !important;
    border-color: var(--rh-navy) !important;
    color: #fff !important;
    opacity: .75;
}

.bg-navy { background: var(--rh-navy) !important; }

/* ── Formulários ── */
.form-control:focus,
.form-select:focus {
    border-color: var(--rh-teal);
    box-shadow: 0 0 0 .2rem rgba(45, 196, 180, .2);
}

/* ── Modais ── */
.modal-content.border-0.shadow-lg { border-radius: .85rem; overflow: hidden; }
.modal-header.bg-navy { background: var(--rh-navy) !important; }

/* ── Toast (Design System) — cores de alerta + barra 12s ── */
.ds-toast-stack {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1090;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    max-width: min(420px, calc(100vw - 2rem));
    pointer-events: none;
}

.ds-toast {
    pointer-events: auto;
    position: relative;
    border-radius: .5rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
    overflow: hidden;
    cursor: pointer;
    min-width: 300px;
    margin-bottom: 0;
    font-size: .88rem;
    font-weight: 500;
    line-height: 1.4;
    animation: ds-toast-enter .35s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes ds-toast-enter {
    from { opacity: 0; transform: translateX(1.25rem); }
    to   { opacity: 1; transform: translateX(0); }
}

.ds-toast__inner {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    padding: 1rem 2.25rem 1rem 1.15rem;
}

.ds-toast__close {
    position: absolute;
    top: .55rem;
    right: .55rem;
    background: none;
    border: none;
    color: inherit;
    opacity: .55;
    padding: .15rem;
    line-height: 1;
    cursor: pointer;
    font-size: 1rem;
}

.ds-toast__close:hover { opacity: 1; }

.ds-toast__progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 6px;
    background: rgba(0, 0, 0, .12);
    overflow: hidden;
}

.ds-toast__progress-fill {
    display: block;
    height: 100%;
    width: 100%;
    transform-origin: left;
    transform: scaleX(1);
    animation: ds-toast-progress linear forwards;
}

@keyframes ds-toast-progress {
    from { transform: scaleX(1); }
    to   { transform: scaleX(0); }
}

/* success */
.ds-toast--success {
    color: #0f5132;
    background: #d1e7dd;
    border: 1px solid #badbcc;
}
.ds-toast--success .ds-toast__progress-fill { background: #0f5132; }

/* error */
.ds-toast--error {
    color: #842029;
    background: #f8d7da;
    border: 1px solid #f5c2c7;
}
.ds-toast--error .ds-toast__progress-fill { background: #842029; }

/* warning */
.ds-toast--warning {
    color: #664d03;
    background: #fff3cd;
    border: 1px solid #ffecb5;
}
.ds-toast--warning .ds-toast__progress-fill { background: #664d03; }

/* info */
.ds-toast--info {
    color: #087990;
    background: #cff4fc;
    border: 1px solid #b6effb;
}
.ds-toast--info .ds-toast__progress-fill { background: #087990; }

/* loading — sem barra, fica até resolver */
.ds-toast--loading {
    color: #084298;
    background: #cfe2ff;
    border: 1px solid #b6d4fe;
}
.ds-toast--loading .ds-toast__inner .spinner-border { color: #084298; }

/* ── Perfil: menu lateral + modais ── */
.perfil-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}
.perfil-menu-card,
.perfil-main-card {
    border: 1px solid #e2e8f0;
    border-radius: 1rem;
    background: linear-gradient(180deg, #fff, #fbfdff);
    box-shadow: 0 10px 28px rgba(15, 23, 42, .08);
}
.perfil-menu-card { padding: 1.25rem; }
.perfil-main-card { min-height: 420px; padding: 1.5rem; }
.perfil-section__header {
    padding-bottom: 1rem;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid #e2e8f0;
}
.perfil-section__title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--rh-navy);
}
.perfil-menu__item.is-active {
    background: #e8f4f3;
    color: var(--rh-navy);
    cursor: default;
}
.perfil-user { padding-bottom: 1rem; border-bottom: 1px solid #e2e8f0; }
.perfil-user__avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: block;
}
.perfil-user__avatar--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--rh-navy), var(--rh-teal));
    color: #fff;
    font-size: 1.35rem;
    font-weight: 700;
}
.perfil-user__meta strong {
    display: block;
    font-size: .95rem;
    color: var(--rh-navy);
    line-height: 1.3;
}
.perfil-user__meta span {
    display: block;
    font-size: .8rem;
    color: #64748b;
    margin-top: .15rem;
    word-break: break-word;
}
.perfil-menu {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    padding: 1rem 0;
}
.perfil-menu__item {
    display: flex;
    align-items: center;
    width: 100%;
    padding: .7rem .85rem;
    border: none;
    border-radius: .6rem;
    background: transparent;
    color: #334155;
    font-weight: 600;
    font-size: .88rem;
    text-align: left;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.perfil-menu__item:hover,
.perfil-menu__item:focus-visible {
    background: #f1f5f9;
    color: var(--rh-navy);
    outline: none;
}
.perfil-confirm-icon {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 0.375rem;
    background: #cfe2ff;
    color: #0d6efd;
    font-size: 1.2rem;
}

.perfil-block {
    margin-top: .5rem;
    padding-top: 1rem;
    border-top: 1px solid #e2e8f0;
}

/* ── Formulário de senha: ícone dentro do input ── */
.input-check-wrap {
    position: relative;
}
.input-check-wrap .form-control {
    padding-right: 2.5rem;
}
.input-check-wrap .form-control.is-valid,
.input-check-wrap .form-control.is-invalid {
    background-image: none;
    padding-right: 2.5rem;
}
.input-check-icon {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 1.1rem;
    line-height: 1;
}

/* ── Requisitos de senha: 2 por linha + bolinhas ── */
.ds-pwd-reqs {
    margin-top: 0.25rem;
    padding: 0.75rem 1rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 0.5rem;
}
.req-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem 1.25rem;
}
.req-list li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8rem;
    line-height: 1.35;
    transition: color 0.15s ease;
}
.req-list .dot {
    flex-shrink: 0;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background: #94a3b8;
    transition: background 0.15s ease;
}
.req-list .dot-gray  { background: #94a3b8; }
.req-list .dot-green { background: #22c55e; }
.req-list .dot-red   { background: #ef4444; }
.req-gray  { color: #64748b; }
.req-ok    { color: #16a34a; }
.req-err   { color: #dc2626; }

@media (max-width: 575.98px) {
    .req-list { grid-template-columns: 1fr; }
}

/* ── Responsivo ── */
@media (max-width: 991.98px) {
    .sidebar-desktop { display: none !important; }
    .admin-main { margin-left: 0 !important; width: 100% !important; }
    .perfil-layout { grid-template-columns: 1fr; }
    .perfil-main-card { min-height: 280px; }
    #mobileSidebar .offcanvas-body {
        height: calc(100vh - 4.5rem);
        overflow: hidden;
        padding: 0;
    }
    #mobileSidebar .sidebar-nav-scroll {
        height: 100%;
        overflow-y: auto;
    }
}
@media (min-width: 992px) {
    .sidebar-desktop {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 1040;
        display: flex !important;
        flex-direction: column;
        width: var(--rh-sidebar-w);
        height: 100vh;
        max-height: 100vh;
        overflow: hidden;
    }
    .admin-main {
        margin-left: var(--rh-sidebar-w);
        width: calc(100% - var(--rh-sidebar-w));
    }
}
