/* ============================================
   COMPONENTS — Cards, Tabelas, Badges, Inputs,
   Modais, Dropdowns e overrides de Bootstrap
   para o suporte a Dark Mode.
   ============================================ */

/* ── CARDS ─────────────────────────────────── */
.card,
.card-module,
.card-kpi {
    background-color: var(--color-card-bg);
    border-color: var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: background-color var(--transition-speed),
        border-color var(--transition-speed),
        box-shadow var(--transition-speed);
}

.card-module {
    cursor: pointer;
    transition: transform 0.2s, background-color var(--transition-speed);
}

.card-module:hover {
    transform: translateY(-5px);
}

.card-kpi {
    border: none;
    border-radius: 10px;
    transition: transform 0.2s, background-color var(--transition-speed);
}

.card-kpi:hover {
    transform: translateY(-3px);
}

.card-footer {
    background-color: var(--color-kpi-footer-bg);
    transition: background-color var(--transition-speed);
}

.icon-box {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 1.5rem;
}

/* ── TABELAS ───────────────────────────────── */
.table {
    color: var(--color-text-primary);
}

.table-hover tbody tr {
    transition: background-color 0.2s, box-shadow 0.2s;
}

.table-hover tbody tr:hover {
    background-color: var(--color-table-hover);
    box-shadow: 0 4px 12px var(--color-card-shadow);
}

/* ── INPUTS / FORMS ────────────────────────── */
.form-control,
.form-select {
    background-color: var(--color-input-bg);
    border-color: var(--color-input-border);
    color: var(--color-text-primary);
    transition: background-color var(--transition-speed),
        border-color var(--transition-speed),
        color var(--transition-speed);
}

.form-control:focus,
.form-select:focus {
    background-color: var(--color-input-bg);
    color: var(--color-text-primary);
}

.form-control::placeholder {
    color: var(--color-text-muted);
}

/* ── AVATAR ────────────────────────────────── */
.avatar-circle {
    width: 42px;
    height: 42px;
    background-color: var(--color-border-light);
    color: var(--color-text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    margin-right: 15px;
    text-transform: uppercase;
    border: 2px solid var(--color-bg-surface);
    transition: background-color var(--transition-speed),
        color var(--transition-speed);
}

/* ── BADGES ────────────────────────────────── */
.badge-status {
    font-size: 0.75rem;
    padding: 0.4em 0.8em;
}

/* ── HOVER UNDERLINE (Navbar profile link) ── */
.hover-underline:hover {
    text-decoration: underline !important;
    opacity: 0.9;
}

/* ── TIMELINE (Ponto) ──────────────────────── */
.timeline-ponto {
    border-left: 2px solid var(--color-border);
    margin-left: 20px;
    padding-left: 20px;
}

.timeline-item {
    position: relative;
    margin-bottom: 20px;
}

.timeline-dot {
    width: 12px;
    height: 12px;
    background: #0d6efd;
    border-radius: 50%;
    position: absolute;
    left: -26px;
    top: 5px;
}

/* Espelho Ponto */
.timeline-line {
    height: 6px;
    border-radius: 3px;
}

/* ── RELÓGIO DIGITAL (Portal Ponto) ────────── */
.relogio-digital {
    font-size: 3.5rem;
    font-weight: 300;
    letter-spacing: -2px;
}

.data-atual {
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.9rem;
}

/* ── BOTÃO PONTO ───────────────────────────── */
.btn-ponto {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    border: 8px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s;
    box-shadow: 0 0 20px rgba(13, 110, 253, 0.3);
}

.btn-ponto:active {
    transform: scale(0.95);
    box-shadow: 0 0 10px rgba(13, 110, 253, 0.5);
}

/* Card VT */
.card-valor {
    background: #e6f9ee;
    color: #0f5132;
    border: 1px solid #badbcc;
}

[data-theme="dark"] .card-valor {
    background: #0f3d2b;
    color: #75b798;
    border-color: #1a5c40;
}

/* Card Menu (Portal) */
.card-menu {
    transition: transform 0.2s, box-shadow 0.2s, background-color var(--transition-speed);
    cursor: pointer;
    border: none;
    text-decoration: none;
    color: inherit;
}

.card-menu:hover {
    transform: translateY(-5px);
    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .15) !important;
}

.icon-menu {
    font-size: 2.5rem;
}

/* Login card */
.login-card {
    width: 100%;
    max-width: 400px;
    padding: 2rem;
    border-radius: 10px;
}

/* ============================================
   DARK MODE — Bootstrap Overrides
   ============================================ */
[data-theme="dark"] .bg-light {
    background-color: var(--color-bg-elevated) !important;
}

[data-theme="dark"] .bg-white {
    background-color: var(--color-card-bg) !important;
}

[data-theme="dark"] .text-dark {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .text-muted {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .text-secondary {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .border-bottom,
[data-theme="dark"] .border-top,
[data-theme="dark"] .border-secondary {
    border-color: var(--color-border) !important;
}

/* Tabela header */
[data-theme="dark"] .table-light,
[data-theme="dark"] thead.bg-light,
[data-theme="dark"] .table-secondary {
    background-color: var(--color-table-header) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .table-light td,
[data-theme="dark"] .table-light th,
[data-theme="dark"] .table-secondary td,
[data-theme="dark"] .table-secondary th {
    background-color: var(--color-table-header) !important;
    color: var(--color-text-secondary) !important;
}

/* Dropdowns */
[data-theme="dark"] .dropdown-menu {
    background-color: var(--color-bg-elevated);
    border-color: var(--color-border);
}

[data-theme="dark"] .dropdown-item {
    color: var(--color-text-primary);
}

[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
    background-color: var(--color-table-hover);
    color: var(--color-text-primary);
}

[data-theme="dark"] .dropdown-header {
    color: var(--color-text-muted);
}

[data-theme="dark"] .dropdown-divider {
    border-color: var(--color-border);
}

/* Modais */
[data-theme="dark"] .modal-content {
    background-color: var(--color-card-bg);
    border-color: var(--color-border);
    color: var(--color-text-primary);
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
    border-color: var(--color-border);
}

/* Input groups */
[data-theme="dark"] .input-group-text {
    background-color: var(--color-bg-elevated);
    border-color: var(--color-input-border);
    color: var(--color-text-secondary);
}

/* Alerts */
[data-theme="dark"] .alert-success {
    background-color: var(--color-alert-success-bg);
    border-color: #1a5c40;
    color: #75b798;
}

[data-theme="dark"] .alert-danger {
    background-color: var(--color-alert-danger-bg);
    border-color: #5c2a33;
    color: #ea868f;
}

[data-theme="dark"] .alert-warning {
    background-color: #332701;
    border-color: #665000;
    color: #ffda6a;
}

[data-theme="dark"] .alert-info {
    background-color: #032830;
    border-color: #055160;
    color: #6edff6;
}

/* Card header com bg-primary (mantém) */
[data-theme="dark"] .card-header.bg-primary {
    background-color: #0a58ca !important;
}

/* Login body */
[data-theme="dark"] body.bg-light-login {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
}

/* Btn-close no dark */
[data-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}