@import url("colors.css");
@import url("fonts.css");

/*Configurações Gerais*/
.material-symbols-outlined {
    font-variation-settings:
        'FILL' 0,
        'wght' 400,
        'GRAD' 0,
        'opsz' 16;
    padding: 0;
    margin: 0;
}

* {
    margin: 0;
    padding: 0;
    font-family: 'Poppins-Regular', sans-serif;
}

html {
    scroll-behavior: smooth;
}

body {
    width: 100%;
    height: 100vh;
    background-color: var(--primary-color) !important;
    color: var(--text-color) !important;
}

body h1 {
    text-align: center !important;
    margin-bottom: 0.3em !important;
}

/*Barra de Navegação*/
.navbar {
    height: var(--navbar-height) !important;
    border-bottom: var(--standard-border);
    background-color: var(--primary-color);
}

.navbar-login {
    border-bottom: none !important;
}

.navbar-text p {
    margin-left: 1em;
}

.container-fluid span {
    color: var(--text-color) !important;
}

.navbar-toggler {
    outline: 0 !important;
    border: 0 !important;
}

.navbar-toggler:focus {
    box-shadow: 0 !important;
}

.navbar-toggler-icon {
    color: var(--text-color) !important;
    background-image: none !important;
}

h6 a {
    text-decoration: none !important;
    color: var(--text-color) !important;
}

/*Sub barra de Navegação*/
.sub-navbar {
    border-bottom: var(--standard-border);
    background-color: var(--primary-color);
    position: fixed !important;
    top: var(--navbar-height) !important;
    height: var(--subnavbar-height) !important;
    /* left: var(--quickaccess-width) !important; */
}

/* .sub-navbar section {
    margin-left: 1em;
}*/

.sub-navbar-items section {
    margin-left: 1em;
}

#subNavbarCarousel {
    display: none !important;
}

.carousel {
    position: relative;
    width: 100%;
}

.slide {
    position: relative !important;
    margin: 0 !important;
    padding: 0 !important;
    left: 0 !important;
    width: 100% !important;
}

.carousel-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    text-align: center;
}

/* --- correção: deixa apenas o item ativo visível --- */
/* padrão: itens escondidos (bootstrap normalmente controla isso) */
#subNavbarCarousel .carousel-item {
    display: none;
    /* itens não ativos ficam ocultos */
    justify-content: center;
    align-items: center;
    padding: 0 !important;
    width: 100%;
    box-sizing: border-box;
}

/* somente o ativo fica visível e com layout flex para centralizar conteúdo */
#subNavbarCarousel .carousel-item.active {
    display: flex;
}

/* mantém carousel-inner como container para centralizar */
#subNavbarCarousel .carousel-inner {
    display: block;
    /* evita conflito com layout de vários itens visíveis */
    height: 100%;
    text-align: center;
    overflow: visible;
}


.carousel-control-prev {
    position: relative;
    left: var(--quickaccess-width) !important;
}

/* Regras para telas com largura menor que 1000px */
@media (max-width: 1000px) {
    #subNavbarCarousel {
        display: flex !important;
    }

    nav.sub-navbar .sub-navbar-items {
        display: none !important;
    }
}

/*Menu Lateral*/
.offcanvas {
    background-color: var(--primary-color) !important;
    color: var(--text-color) !important;
}

.btn-close {
    background: none !important;
    opacity: 100% !important;
    padding-top: 0 !important;
}

.btn-close svg {
    color: var(--text-color);
}

.btn-close svg:hover {
    cursor: pointer;
}

hr {
    height: 0 !important;
    border: var(--thin-border) !important;
    opacity: 100% !important;
    width: 80%;
    margin: 0 !important;
}

.options {
    margin-top: 0.5em;
}

.options svg {
    color: var(--text-color);
    margin-right: 0.5em;
    width: 24px;
    height: 24px;
}

.options span {
    color: var(--text-color);
}

.offcanvas-body span,
.carousel-item span,
.sub-navbar span {
    margin-right: 0.3em;
}

.options a {
    text-decoration: none !important;
    color: var(--text-color) !important;
}

.options a:hover {
    text-decoration: none !important;
}

/*Barra de Ferramentas de Acesso Rápido*/
.quickaccess {
    height: calc(100vh - var(--navbar-height) - var(--footer-height));
    width: var(--quickaccess-width);
    border-right: var(--standard-border);
    background-color: var(--primary-color);
    top: var(--navbar-height);
    left: 0;
    position: fixed;
}

.quickaccess a {
    text-decoration: none !important;
}

.quickaccess span {
    color: var(--text-color) !important;
    margin: 0.5em;
    width: 24px;
    height: 24px;
}

/*Tela principal*/
main {
    width: calc(100% - var(--quickaccess-width));
    height: calc(100vh - var(--navbar-height) - var(--footer-height) - var(--subnavbar-height));
    top: calc(var(--navbar-height) - var(--footer-height) / 2);
    margin-bottom: calc(var(--footer-height));
    background-color: var(--primary-color);
    overflow-y: scroll !important;
    overflow-x: auto !important;
    left: calc(var(--quickaccess-width) / 2) !important;
}

main.login,
main.recover,
main.reset {
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.main-content {
    margin-top: calc(var(--navbar-height) + var(--subnavbar-height) * 2);
    margin-bottom: calc(var(--footer-height) * 2);
    /* left: calc(var(--quickaccess-width)/2); */
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    width: 100% - var(--quickaccess-width);
    height: calc(100vh - var(--navbar-height) - var(--footer-height));
}

#deleteUsers,
#lockUsers,
#unlockUsers,
#deleteStudents,
#lockStudents,
#unlockStudents,
#generalConfigs,
#searchContracts {
    margin-top: 0 !important;
    justify-content: center !important;
}

section#chatsList ul {
    padding-bottom: 2rem !important;
}

#studentsForm,
#companiesForm {
    display: none;
}

#studentsForm hr,
#companiesForm hr,
#parentsButtons {
    position: relative !important;
    width: 100% !important;
    margin-top: 2em !important;
    margin-bottom: 2em !important;
}

caption {
    color: var(--text-color) !important;
}

#listIssues {
    justify-content: center !important;
    width: 70% !important;
}

.form-switch {
    padding-right: 1rem !important;
}

@media (max-width: 800px) {
    .main-content {
        margin-top: calc(var(--navbar-height)) !important;
    }
}

.main-content h1,
.main-content label {
    color: var(--text-color);
}

.main-content hr {
    height: 0 !important;
    border: var(--thin-border) !important;
    opacity: 100% !important;
    width: 120%;
    margin-bottom: 1em !important;
}

.main-content .mb-1 hr {
    position: relative !important;
    width: 100% !important;
    margin-top: 1em !important;
    margin-bottom: 1em !important;
}

.main-content form a {
    text-decoration: none !important;
    color: var(--text-color) !important;
}

.main-content form a svg {
    color: var(--text-color) !important;
    margin-right: 0.5em;
}

form h3,
form h4 {
    color: var(--text-color);
}

.main-content form {
    position: relative;
    width: 100%;
}

.main-content input[type="submit"],
.main-content input[type="reset"] {
    margin-bottom: 1em;
}

@media (max-width: 800px) {
    .main-content hr {
        width: 90%;
    }

    .main-content form {
        position: relative;
        width: 90%;
    }
}

@media (max-width: 500px) {
    .main-content hr {
        width: 80%;
    }

    .main-content form {
        position: relative;
        width: 80%;
    }
}

@media (max-width: 400px) {
    .main-content hr {
        width: 60%;
    }

    .main-content form {
        position: relative;
        width: 60%;
    }
}

/*Formulário de Login*/
.card {
    width: 30em !important;
    border-radius: 0 !important;
}

.card-title {
    width: 100%;
    height: 2em;
    background-color: var(--primary-color);
    color: var(--text-color) !important;
    border: var(--standard-border);
}

.card-body {
    padding: 0 !important;
}

.card-body-map {
    padding: 1em !important;
}

.card-body form {
    padding: 4rem 1rem 1rem 1rem;
}

.card-body label h5 {
    color: var(--primary-color);
}

.card-body svg {
    color: var(--primary-color);
}

.card-body a {
    text-decoration: none !important;
    color: var(--primary-color) !important;
    font-weight: 600;
}

.card-body a:hover {
    text-decoration: underline !important;
}

input[type="reset"],
input[type="submit"] {
    font-weight: 600;
}

.btn {
    border-radius: 0 !important;
    width: 100%;
}

/*Rodapé*/
footer {
    width: 100%;
    height: var(--footer-height);
    border-top: var(--standard-border);
    color: var(--text-color);
    background-color: var(--primary-color);
}

footer h6 {
    font-weight: bolder;
}

footer h6 svg {
    cursor: pointer;
}

.modal-content {
    background-color: var(--primary-color) !important;
    color: var(--text-color) !important;
}

/*Alertas*/
.alert {
    position: absolute !important;
    bottom: 0 !important;
    right: 0 !important;
    z-index: 3 !important;
    margin-right: 1em;
    display: inline-flex !important;
    align-items: center !important;
}

.success-close,
.warning-close,
.danger-close {
    position: absolute;
    right: 0;
    margin-right: 0.5em;
    cursor: pointer;
    background: transparent;
    border: none;
    padding: 0;
    text-decoration: none;
    display: flex;
    align-items: center;
}

.success-close {
    color: var(--success-color);
}

.warning-close {
    color: var(--warning-color);
}

.danger-close {
    color: var(--danger-color);
}

/*Chats*/
.chat-container {
    bottom: calc(var(--footer-height) + 1rem);
    margin-top: 3rem;
    height: 100vh !important;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.chat-container::-webkit-scrollbar {
    display: none;
}

#chatForm {
    position: sticky;
    bottom: 1rem;
}

.message {
    max-width: 100%;
    margin: 8px 0;
    padding: 10px 15px;
    border-radius: 15px;
    word-wrap: break-word;
}

.sent {
    background-color: var(--sent-color);
    align-self: flex-end;
    text-align: right;
    margin-left: auto;
}

.received {
    background-color: var(--received-color);
    align-self: flex-start;
    text-align: left;
    margin-right: auto;
}

.message-meta {
    font-size: 0.8em;
    color: #555;
    margin-bottom: 3px;
}

/*Notification Toasts*/
.toast {
    background-color: var(--sent-color) !important;
}

.toast-header {
    background-color: var(--received-color) !important;
}

.me-auto {
    padding-left: 0.4rem !important;
}

.btn-close-toast {
    margin-right: 0.2rem !important;
    margin-bottom: 0.6rem !important;
}

.toast-body {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.text-white {
    color: var(--text-color) !important;
}

/*Link Buttons*/
a.btn-icon,
a.btn-icon span {
    text-decoration: none !important;
    color: #000000;
}

a.btn-icon:hover,
a.btn-icon span {
    text-decoration: none !important;
}

/* ToTop botão fixo */
#btnToTop {
    position: fixed;
    right: 1.5rem;
    bottom: 3rem;
    width: 24px;
    height: 24px;
    padding: 0;
    z-index: 1030;
    /* acima de modais padrão do bootstrap (1050) */
    border: none;
    cursor: pointer;

    /* aparência */
    background-color: #ffffff;
    /* branco */
    color: #222;
    /* ícone escuro para contraste */
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
    opacity: 0.70;
    /* transparência por padrão */
    transition: opacity 180ms ease, transform 180ms ease, box-shadow 180ms ease;
    transform: translateY(0);
    display: none;
    /* escondido por padrão até rolar */
}

/* hover / focus deixa 100% */
#btnToTop:hover,
#btnToTop:focus {
    opacity: 1;
    outline: none;
    transform: translateY(-2px);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18);
}

/* círculo e tamanho do ícone */
#btnToTop .material-symbols-outlined {
    font-size: 20px;
    line-height: 1;
}

.btn-dashboard {
    right: 0.5rem !important;
}

/* versão menor em telas pequenas (opcional) */
@media (max-width: 480px) {
    #btnToTop {
        right: 0.6rem;
        bottom: 0.6rem;
        width: 44px;
        height: 44px;
    }
}

/* forçar quebra de linhas nas colunas de Ocupação / Sinônimos da tabela CBO */
.cbo-ocupacao,
.cbo-sinonimos {
    white-space: normal !important;
    word-wrap: break-word;
    /* compatibilidade antiga */
    overflow-wrap: break-word;
    /* padrão moderno */
    word-break: break-word;
    hyphens: auto;
    max-width: 38ch;
    /* opcional: controla largura visual aproximada */
}

.sub-navbar {
    position: fixed;
    /* já existe, mas reforçando */
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1050;
    /* acima de outros elementos */
}

/* MUITO IMPORTANTE: permitir dropdown aparecer fora */
.sub-navbar,
.sub-navbar .container-fluid,
.sub-navbar .sub-navbar-items,
.sub-navbar .options {
    overflow: visible !important;
}

/* Grupo split do submenu */
.subnav-split {
    display: flex;
    align-items: center;
}

/* Estilo base dos botões do submenu */
.subnav-btn {
    background: transparent;
    border: none;
    color: inherit;
    text-decoration: none;
    /* padding: 0.5rem 0.75rem; */
    display: flex;
    align-items: center;
    cursor: pointer;
    position: relative;
    height: 100%;
    margin-left: 0.25rem;
}

.subnav-btn:hover {
    background-color: #555 !important;
}

/* Hover consistente com os outros itens */
.subnav-btn:hover,
.subnav-btn:focus {
    background-color: rgba(0, 0, 0, 0.2) !important;
    /* ajuste conforme seu tema */
    text-decoration: none !important;
}

/* Evita quebra visual entre botão e seta */
.subnav-split .subnav-btn+.subnav-btn {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.dropdown-menu {
    background-color: var(--primary-color) !important;
    color: var(--text-color) !important;
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.10),
        0 8px 20px rgba(0, 0, 0, 0.08) !important;
}

.dropdown-item:hover {
    background-color: transparent !important;
}

.dropdown-divider {
    position: relative !important;
    width: 100% !important;
}

@media (max-width: 1000px) {
    .sub-navbar {
        position: fixed !important;
        top: var(--navbar-height) !important;
        height: var(--subnavbar-height) !important;
        left: 0;
        width: 100%;
        z-index: 1050;
        overflow: visible !important;
    }

    .sub-navbar .container-fluid {
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 0.5rem;
        box-sizing: border-box;
    }

    .sub-navbar,
    .sub-navbar .container-fluid,
    .sub-navbar .sub-navbar-items,
    .sub-navbar .options {
        overflow: visible !important;
    }

    .carousel-item {
        position: relative;
        top: 35% !important;
    }

    #subNavbarCarousel .carousel-item {
        position: relative !important;
    }

    #subNavbarCarousel .subnav-split {
        text-align: center !important;
        display: flex !important;
        position: relative !important;
        left: calc(var(--quickaccess-width) - 2rem) !important;
        padding-bottom: 0.5rem !important;
        /* top: 50% !important; */
        /* transform: translate(-50%, -50%) !important; */
        /* max-width: calc(100% - 2rem) !important; */
        /* box-sizing: border-box !important;  */
        justify-content: center !important;
        align-items: center !important;
        /* pointer-events: auto !important; */
    }

    #subNavbarCarousel .subnav-split .subnav-btn,
    #subNavbarCarousel .subnav-split>a {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    #subNavbarCarousel .subnav-split>a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        padding: 0.3rem 0.6rem;
    }

    #subNavbarCarousel .subnav-split>.subnav-btn.dropdown-toggle-split {
        padding: 0.25rem 0.45rem;
    }

    #subNavbarCarousel {
        display: flex !important;
        align-items: center;
        justify-content: center;
        height: 100%;
    }

    #subNavbarCarousel .options {
        margin-left: 0 !important;
        width: 100%;
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

/* 2) Forçar z-index do dropdown para ficar acima da sub-navbar (evita ficar "atrás") */
.sub-navbar .dropdown-menu,
#subNavbarCarousel .dropdown-menu,
.sub-navbar .dropend .dropdown-menu {
    z-index: 2500 !important;
    /* garante que apareça acima de .sub-navbar (z-index:1050) */
}

/* 3) Ajuste específico para dropend (garantir que aparece encostado à direita do trigger) */
.dropend>.dropdown-menu {
    left: 100% !important;
    top: 0 !important;
    transform: none !important;
    margin-left: 0.15rem;
    /* pequeno espaçamento */
}

/* 4) Em telas pequenas converta dropend para dropdown "normal" (evita que saia da tela) */
/* @media (max-width: 768px) {
  .dropend > .dropdown-menu {
    left: 0 !important;
    right: auto !important;
    top: 100% !important;
    margin-left: 0 !important;
  }
} */

/* Relógio digital moderno */
#clock {
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 600;
    letter-spacing: 0.12em;
    color: #555;
    padding: 0.45em 0.9em;
    border-radius: 0.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 8.5ch;
    text-align: center;
    user-select: none;
}

.card-body-map {
    padding: 1.25rem;
}

.punches-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.5rem;
}

#map {
    width: 100%;
    min-height: 260px;
    height: 300px;
    border-radius: 0.5rem;
}

#clock {
    margin-bottom: 0.25rem;
}


@media (max-width: 768px) {
    #map {
        height: 260px;
    }
}

@media (max-width: 480px) {
    #map {
        height: 220px;
    }
}

/* .card-body-map .d-flex {
    flex-wrap: wrap;
    gap: 1rem;
}

.card-body-map .d-flex > div:first-child {
    flex: 1 1 260px;
    min-width: 260px;
}

.card-body-map .d-flex > div:last-child {
    flex: 0 1 auto;
    text-align: right;
}

#punchBtn {
    width: 100%;
    min-width: 180px;
} 

#address,
#coords {
    line-height: 1.35;
    word-break: break-word;
}*/

@media (max-width: 576px) {

    .punches-container {
        width: auto !important;
    }

    .card-body-map .d-flex {
        flex-direction: column;
        align-items: stretch;
    }

    .card-body-map .d-flex>div {
        width: auto;
        text-align: left;
    }

    #punchBtn {
        width: 100%;
    }

    #status {
        text-align: center;
    }
}

.table-responsive {
    margin-top: 0.5rem;
}

#punchTable th,
#punchTable td {
    white-space: nowrap;
    vertical-align: middle;
}

@media (max-width: 576px) {
    #punchTable {
        font-size: 0.85rem;
    }
}

h1 {
    text-align: center;
}

h3 {
    margin-top: 0.75rem;
}

/* Summary Stats */
.summary-stat {
    padding: 12px;
    border-radius: 8px;
    text-align: center;
}

.summary-stat.total {
    background-color: var(--secondary);
    color: var(--secondary-foreground);
}

.summary-stat.present {
    background-color: var(--status-present-soft);
    color: var(--status-present);
}

.summary-stat.absent {
    background-color: var(--status-absent-soft);
    color: var(--status-absent);
}

.summary-stat.late {
    background-color: var(--status-late-soft);
    color: var(--status-late);
}

.summary-stat.justified {
    background-color: var(--status-justified-soft);
    color: var(--status-justified);
}

.progress-bar-custom {
    height: 8px;
    border-radius: 9999px;
    background-color: var(--muted);
    overflow: hidden;
    display: flex;
    margin-top: 1rem;
}

.progress-segment {
    height: 100%;
    transition: width 0.3s ease;
}

/* Student Card */
.student-card {
    background-color: var(--card);
    border-radius: 12px;
    padding: 1rem;
    box-shadow: var(--shadow-md);
    transition: all 0.2s ease;
    margin-bottom: 12px;
}

.student-card:hover {
    box-shadow: var(--shadow-lg);
}

.student-card.selected {
    border: 2px solid var(--primary);
}

.student-checkbox {
    width: 20px;
    height: 20px;
    border: 2px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.student-checkbox.checked {
    background-color: var(--primary);
    border-color: var(--primary);
    color: white;
}

.status-badge {
    padding: 4px 12px;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
    display: inline-block;
}

.status-badge.present {
    background-color: var(--status-present-soft);
    color: var(--status-present);
}

.status-badge.absent {
    background-color: var(--status-absent-soft);
    color: var(--status-absent);
}

.status-badge.late {
    background-color: var(--status-late-soft);
    color: var(--status-late);
}

.status-badge.justified {
    background-color: var(--status-justified-soft);
    color: var(--status-justified);
}

.status-btn {
    flex: 1;
    height: 40px;
    border-radius: 8px;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    background-color: var(--muted);
    color: var(--muted-foreground);
}

.status-btn:hover {
    background-color: var(--secondary);
}

.status-btn.active.present {
    background-color: var(--status-present);
    color: white;
}

.status-btn.active.absent {
    background-color: var(--status-absent);
    color: white;
}

.status-btn.active.late {
    background-color: var(--status-late);
    color: white;
}

.status-btn.active.justified {
    background-color: var(--status-justified);
    color: white;
}

/* Animations */
@keyframes slide-up {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes pulse-soft {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.7;
    }
}

.animate-slide-up {
    animation: slide-up 0.3s ease-out;
}

.animate-fade-in {
    animation: fade-in 0.2s ease-out;
}

.avatar-container {
    text-align: center;
}

.avatar-wrapper {
    position: relative;
    width: 200px;
    height: 200px;
    margin: 0 auto 30px;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.avatar-wrapper:hover {
    transform: scale(1.05);
}

.avatar-circle {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
    overflow: hidden;
    position: relative;
}

.avatar-circle img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: none;
}

.avatar-circle.has-image img {
    display: block;
}

.avatar-circle.has-image .avatar-placeholder {
    display: none;
}

.avatar-placeholder {
    font-size: 80px;
    color: #667eea;
}

.avatar-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.avatar-wrapper:hover .avatar-overlay {
    opacity: 1;
}

.avatar-overlay i {
    color: white;
    font-size: 40px;
}

.upload-text {
    color: white;
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 10px;
}

.upload-hint {
    color: rgba(255, 255, 255, 0.8);
    font-size: 14px;
}

.btn-effect {
    margin-top: 20px;
    color: white;
    padding: 10px 30px;
    border-radius: 50px !important;
    font-weight: 500;
    transition: all 0.3s ease;
}

.btn-effect:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);
}

#fileInput {
    display: none;
}

.card-custom {
    background: rgba(255, 255, 255, 0.95);
    border-radius: 20px;
    padding: 40px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.text-black {
    color: #000000;
}

/* /public/css/punches.css */

/* layout geral */
.punches-container {
    max-width: 1100px;
    width: 100%;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    margin: 0 auto;
}

/* mapa responsivo (antes estava inline) */
.map-responsive {
    width: 100%;
    height: 320px;
    /* desktop */
    border-radius: 6px;
    min-height: 200px;
}

/* linha com info + botão */
.punch-row {
    gap: .5rem;
}

/* info textual (relógio, endereço) */
.punches-info {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    min-width: 0;
}

/* deixa o botão grande e agradável em mobile */
#punchBtn {
    min-width: 170px;
}

/* status text alignment on small screens */
#status {
    word-break: break-word;
}

/* tabela: tornar legível em mobile */
.table-responsive {
    overflow-x: auto;
}

/* Esconder colunas menos importantes em telas pequenas */
@media (max-width: 576px) {
    .map-responsive {
        height: 220px;
    }

    .punch-row {
        flex-direction: column;
        align-items: stretch;
    }

    /* botão ocupa 100% em mobile */
    #punchBtn {
        width: 100%;
    }

    /* esconder colunas Lat/Lon para deixar a tabela compacta */
    #punchTable th:nth-child(4),
    #punchTable td:nth-child(4),
    #punchTable th:nth-child(5),
    #punchTable td:nth-child(5) {
        display: none;
    }

    /* tornar célula 'Hora' mais destacada */
    #punchTable td,
    #punchTable th {
        white-space: nowrap;
    }

    /* reduzir padding das células para economia de espaço */
    #punchTable .table-sm td,
    #punchTable .table-sm th {
        padding: .35rem .45rem;
        font-size: 0.95rem;
    }
}

/* Ajustes médios */
@media (min-width: 577px) and (max-width: 900px) {
    .map-responsive {
        height: 280px;
    }
}

/* --- START: FIX RESPONSIVIDADE / EVITAR SCROLL HORIZONTAL --- */
/* Caixa de sizing global (evita soma de padding gerar overflow) */
html {
    box-sizing: border-box;
}

*,
*::before,
*::after {
    box-sizing: inherit;
}

/* Forçar esconder overflow-x geral da área principal */
main {
    overflow-x: hidden !important;
    /* evita barra horizontal */
    overflow-y: auto !important;
    /* permite rolagem vertical */
}

/* Evita que regras como width:120% provoquem overflow */
.main-content hr {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Garantir que containers centrais respeitem padding sem extrapolar */
.punches-container {
    box-sizing: border-box;
    max-width: 1100px;
    width: 100%;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    margin-left: auto;
    margin-right: auto;
}

/* Ajustes específicos para dispositivos móveis */
@media (max-width: 1000px) {

    /* tornar main full-width e remover deslocamentos que podem gerar overflow */
    main {
        width: 100% !important;
        left: 0 !important;
        padding-left: calc(var(--quickaccess-width) + 0.5rem);
        padding-right: 0.5rem;
    }

    .main-content {
        width: 100% !important;
        margin-top: calc(var(--navbar-height) + var(--subnavbar-height) + 1rem) !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* garantir que o card não exceda a largura da tela */
    .card {
        width: 100% !important;
    }

    /* adaptar tabelas / colunas para quebrar em mobile (evita overflow) */
    #punchTable th,
    #punchTable td {
        white-space: normal !important;
        word-break: break-word !important;
        overflow-wrap: anywhere !important;
    }

    .table-responsive {
        overflow-x: auto;
        /* mantém comportamento, mas evita scroll do body */
    }
}

/* ajustes fina para telas bem pequenas */
@media (max-width: 576px) {
    .main-content hr {
        width: 90% !important;
    }

    .map-responsive {
        height: 220px;
    }

    .card-body-map {
        padding: 0.75rem !important;
    }

    #punchBtn {
        width: 100% !important;
    }

    .punch-row {
        gap: .5rem;
    }
}

/* --- END: FIX RESPONSIVIDADE / EVITAR SCROLL HORIZONTAL --- */

/* --- AVATAR RESPONSIVO: substituir regras fixas por sizing fluido --- */

/* container do avatar (controla o tamanho visível) */
.avatar-wrapper {
    /* tamanho fluido: nunca menor que 48px, cresce com a viewport, máximo 120px */
    width: clamp(48px, 11vw, 120px);
    height: clamp(48px, 11vw, 120px);
    margin: 0 auto 0;
    /* removes big bottom spacing on cards */
    transition: transform 0.18s ease, width 0.18s ease, height 0.18s ease;
    flex: 0 0 auto;
    /* evita que o avatar estique com o flex container */
    box-sizing: border-box;
}

/* círculo que contém a imagem */
.avatar-circle {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
    background: #fff;
}

/* imagem responsiva: cobre o círculo e preserva proporção */
.avatar-circle img.avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    /* mostramos por CSS quando .has-image exist */
}

/* placeholder (ícone) escala com o tamanho do avatar */
.avatar-placeholder {
    font-size: clamp(20px, 6vw, 48px);
    color: #667eea;
    line-height: 1;
}

/* se houver imagem, escondemos o placeholder (mantém a lógica atual) */
.avatar-circle:not(.has-image) img.avatar-img {
    display: none;
}

.avatar-circle.has-image .avatar-placeholder {
    display: none;
}

/* overlay / hover continuam funcionando */
.avatar-overlay {
    border-radius: 50%;
}

/* garantir que no layout de aluno o texto que vem depois quebre corretamente */
.student-card .flex-fill {
    min-width: 0;
}

/* ajustes específicos para telas pequenas */
@media (max-width: 576px) {
    .avatar-wrapper {
        width: clamp(40px, 18vw, 80px);
        height: clamp(40px, 18vw, 80px);
        margin-right: 0.6rem;
        /* deixa um pouco de espaço entre avatar e textos */
    }

    .student-card {
        padding: .65rem;
    }

    .status-badge {
        font-size: 0.68rem;
        padding: 3px 8px;
    }
}