:root {
  --primary: #2274a5;
  --primary-dark: #174d72;
  --primary-light: #e7f3fa;
  --accent: #44bbef;
  --success: #32cb78;
  --danger: #e74c3c;
  --warning: #ffb703;
  --text-main: #22324d;
  --text-light: #fff;
  --text-muted: #6b7c93;
  --bg-main: #f3f7fa;
  --bg-card: #fff;
  --bg-card-dark: #222b3a;
  --bg-table-even: #f6fafc;
  --shadow: 0 2px 16px rgba(34,116,165,.08);

  /* Tokens de cartão e tipografia comuns */
  --card-bg: var(--bg-card);
  --card-border: #e3eaf6;
  --card-shadow: var(--shadow);
  --card-radius: 12px;
  --card-hover-shadow: 0 5px 20px rgba(34,116,165,0.15);
  --text-strong: var(--text-main);
  --text-secondary: var(--text-muted);

  /* Variáveis para .form-page-form inputs (Light Mode Defaults) */
  --form-page-input-bg: #f9fbfd;
  --form-page-input-text: #22324d;
  --form-page-input-border: #b6d8f0;
  --form-page-input-focus-bg: #fff;
  --form-page-input-focus-border: #23aaff;
  --form-page-input-disabled-bg: #e9ecef;
  --form-page-input-disabled-text: #b6bfd6;
  --form-page-input-disabled-border: #c5d3e5;

  /* Tokens comuns de cartões/painéis */
  --card-bg: var(--bg-card);
  --card-border: #e3eaf6;
  --card-shadow: var(--shadow);
  --card-hover-shadow: 0 5px 20px rgba(34,116,165,0.15);
  --card-radius: 12px;
  --text-strong: var(--text-main);
  --text-secondary: var(--text-muted);

  /* Bridges para CSS específicos (ferias.css) */
  --primary-color: var(--primary);
  --primary-color-light: var(--primary-light);
  --text-color: var(--text-main);
  --text-color-secondary: var(--text-muted);
  --border-color: var(--card-border);
  --background-color-light: var(--bg-card);
  --background-color-hover: var(--bg-table-even);
}

html {
  box-sizing: border-box;
}
*, *:before, *:after {
  box-sizing: inherit;
}
body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Inter', Arial, sans-serif;
  color: var(--text-main);
  background: var(--bg-main);
  min-height: 100vh;
  transition: background .3s;
}

/* HEADER */
.header-fixo {
  background: var(--primary);
  color: var(--text-light);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 99;
  box-shadow: 0 3px 18px rgba(34,116,165,0.13);
  font-size: 1em;
}
.header-logo img {
  height: 50px;
  margin-right: 12px;
  vertical-align: middle;
}
.header-logo {
  font-size: 1.15rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: .02em;
}
.header-utilizador {
  font-size: 1.06rem;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
}
.menu-mobile-toggle {
  display: none; /* Escondido em desktop por defeito */
  background: transparent;
  border: none;
  color: var(--text-light); /* Cor do ícone, assume header com fundo escuro */
  font-size: 1.6rem; /* Ajustar conforme necessário */
  cursor: pointer;
  padding: 0.5rem; /* Área de clique */
}


/* MENU LATERAL */
.menu-lateral {
  position: fixed;
  left: 0; top: 64px; bottom: 0;
  width: 210px;
  background: #fff;
  border-right: 1px solid #e7eef7;
  box-shadow: 1px 0 6px rgba(34,116,165,0.06);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 90;
  transition: width .3s;
}
.menu-lateral a {
  padding: 13px 22px;
  color: var(--primary-dark);
  text-decoration: none;
  font-size: 1.04rem;
  display: flex;
  align-items: center;
  gap: 12px;
  border-left: 4px solid transparent;
  border-radius: 0 13px 13px 0;
  font-weight: 500;
  letter-spacing: .01em;
  transition: background .13s, color .13s, border .16s;
}
.menu-lateral a.active, .menu-lateral a:hover {
  background: #22bfff22;
  color: #23c0f7;
  font-weight: bold;
}
.menu-lateral a .fa,
.menu-lateral a .fas,
.menu-lateral a .far,
.menu-lateral a .fa-solid,
.menu-lateral a .fa-regular {
  width: 22px;            /* largura fixa para alinhar todos os textos */
  flex: 0 0 22px;         /* não encolhe, não cresce */
  text-align: center;     /* centra o ícone dentro da largura fixa */
  margin-right: 0;        /* o espaçamento já é dado por gap no flex */
}
.menu-lateral .txt { flex: 1; }

/* MAIN */
.dashboard-main {
  margin-left: 210px;
  padding: 80px 18px 40px 18px;
  min-height: 100vh;
  background: var(--bg-main);
  transition: background .3s;
}
.overlay-menu {
  display: none; /* Escondido por defeito */
  position: fixed;
  inset: 0; /* Cobre a tela toda */
  background: rgba(0,0,0,0.45);
  z-index: 1000; /* Abaixo do menu lateral, acima do conteúdo principal */
}
/* Mostrar overlay quando o menu está aberto */
.menu-lateral.open + .overlay-menu {
  display: block;
}
.container {
  background: var(--card-bg);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  padding: 32px 32px 28px 32px;
  margin-bottom: 40px;
  max-width: 1280px;    /* <- MAIOR! */
  margin-left: auto;
  margin-right: auto;
  border: 1px solid var(--card-border);
  color: var(--text-main);
  width: 100%;
}

h3 {
  margin-top: 0;
  font-weight: 700;
  color: var(--primary-dark);
  font-size: 1.16rem;
  margin-bottom: 21px;
}

/* Utilitários de painel (para uniformizar blocos em todas as páginas) */
.panel {
  background: var(--card-bg);
  color: var(--text-main);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  padding: 16px;
  margin-bottom: 16px; /* Espaçamento consistente entre painéis */
}
.panel-header {
  padding: 8px 12px 12px 12px;
  margin: -16px -16px 12px -16px; /* estende até às bordas do painel */
  border-bottom: 1px solid var(--card-border);
  background: transparent;
  font-weight: 800;
  color: var(--text-strong);
  font-size: 1.06rem; /* Uniformiza h2/h3 com a mesma escala */
  line-height: 1.3;
  display: flex;
  align-items: center;
  gap: 8px;
}
.panel-header i { color: var(--primary); }
.panel-actions { display: flex; gap: .5rem; align-items: center; }

/* Variantes de botão opcionais (não afetam .btn existente) */
.btn--primary { background: var(--primary); color: var(--text-light); border: 1px solid var(--primary); }
.btn--primary:hover { background: var(--primary-dark); }
.btn--secondary { background: transparent; color: var(--primary); border: 1px solid var(--primary); }
.btn--secondary:hover { background: var(--primary-light); }
.btn--ghost { background: transparent; color: var(--text-main); border: 1px solid var(--card-border); }
.btn--ghost:hover { background: var(--background-color-hover, #eef5fb); }

/* Estilos para a página de termos legais */
.legal-content {
    line-height: 1.6;
    padding-top: 15px;
}
.legal-content h3 {
    color: var(--primary-dark);
    margin-top: 20px;
    margin-bottom: 10px;
    border-bottom: 2px solid #e7eef7;
    padding-bottom: 5px;
}
.legal-content h3:first-child {
    margin-top: 0;
}
.legal-content p {
    text-align: justify;
}

/* CARDS (estilo unificado) */
.cards-stats {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 15px;
  margin-bottom: 32px;
}
.card-stat {
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: 21px 14px;
  box-shadow: var(--card-shadow);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 90px;
  border: 1px solid var(--card-border);
  transition: box-shadow .17s, transform .17s, background .2s;
}
.card-stat:hover {
  box-shadow: var(--card-hover-shadow);
  transform: translateY(-2px) scale(1.025);
}
.stat-title {
  color: var(--text-secondary);
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 1.02em;
  display: flex;
  align-items: center;
  gap: 7px;
  letter-spacing: .1px;
}
.stat-value {
  font-size: 1.7em;
  font-weight: 900;
  color: var(--text-strong);
  margin-bottom: 0;
}

/* Lista curta para próximos eventos/ferias em painéis */
.lista-ferias-dashboard { margin: .25rem 0 0 0; padding-left: 1.1rem; }
.lista-ferias-dashboard li { margin: .25rem 0; }

/* Ícone circular unificado para cards estatísticos (se existir) */
.card-stat .stat-icon, .stat-card-icon {
  width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  color: var(--primary); background: var(--primary-light);
  box-shadow: 0 0 0 0 rgba(0,0,0,0.0);
}

/* FORMULÁRIOS */

/* Layouts utilitários para formulários em painéis (ex.: Configurações) */
.form-2col {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 24px; /* linhas x colunas */
  align-items: start;
}
.form-2col .col { display: flex; flex-direction: column; }
@media (max-width: 768px) {
  .form-2col { grid-template-columns: 1fr; gap: 14px; }
}

/* Espaçamento consistente entre grupos */
.form-group { margin-bottom: 14px; }
.form-group label { margin-bottom: 6px; font-weight: 600; }

/* Harmonizar cor dos labels no bloco SMTP com o campo de notificações */
.form-config-smtp .form-2col label,
.form-config-smtp-test .form-2col label {
  color: #40bfff; /* mesma cor usada em .form-group label */
  font-weight: 600;
  margin-bottom: 6px;
}

@media (prefers-color-scheme: dark) {
  /* Garantir que o label específico do email de teste acompanha a mesma cor */
  .form-config-smtp-test label[for="email_teste"] { color: #33c6fe !important; }
}

/* Ações do formulário com respiro superior */
.form-actions { margin-top: 12px; display: flex; gap: 10px; align-items: center; }

/* Painéis de formulário: mais respiro interno para inputs densos */
.form-section.panel { padding: 20px; }
.form-section.panel .panel-header { margin-bottom: 16px; }

/* Inputs e selects com altura e espaçamentos harmonizados */
.form-section input[type="text"],
.form-section input[type="email"],
.form-section input[type="password"],
.form-section input[type="number"],
.form-section select {
  height: 42px;
}

/* Emparelhar o botão "Testar Email" à direita quando usado em 2 colunas */
.form-config-smtp-test .form-2col .col:last-child { display: flex; justify-content: flex-end; }

/* Melhorar espaçamento vertical entre painéis consecutivos */
.panel + .panel { margin-top: 18px; }



.form-row {
    display: flex;
    gap: 32px;
    margin-bottom: 20px;
}
.form-group {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.form-group input,
.form-group textarea {
    width: 100%;
    min-height: 38px;
    border-radius: 8px;
    border: 1px solid #7f9cbf;
    padding: 8px 12px;
    font-size: 1em;
    font-family: inherit;
    box-sizing: border-box;
    margin-top: 2px;
}
.form-group textarea {
    resize: vertical;
    min-height: 38px;
}
.form-group label {
    color: #40bfff;
    margin-bottom: 2px;
    font-weight: 500;
}
form input[type="text"],
form input[type="email"],
form input[type="password"],
form input[type="date"],
form input[type="number"],
form select {
  width: 100%;
  padding: 10px 13px;
  border: 1px solid #bed3e7;
  border-radius: 7px;
  font-size: 1rem;
  transition: border .13s;
}
form input:focus, form select:focus {
  border-color: var(--primary);
  outline: none;
}

/* Placeholders mais legíveis */
form input::placeholder, .form-section input::placeholder, .form-section select::placeholder {
  color: #9bb3c9;
  opacity: 1; /* garante a cor definida em alguns browsers */
}
button, .btn {
  background: var(--primary);
  color: var(--text-light);
  padding: 10px 20px;
  border: none;
  border-radius: 8px;
  font-size: 1.04rem;
  font-weight: 700;
  box-shadow: 0 2px 7px rgba(34,116,165,0.09);
  cursor: pointer;
  transition: background .12s, box-shadow .11s, transform .12s;
  display: inline-block;
  text-decoration: none; /* remove sublinhado em anchors com .btn */
  letter-spacing: .07px;
}
button:hover, .btn:hover {
  background: var(--primary-dark);
  color: #fff;
  box-shadow: 0 5px 15px rgba(68,187,239,0.11);
  transform: translateY(-1px) scale(1.01);
  text-decoration: none; /* mantém sem sublinhado no hover */
}
/* Espaço entre ícone e texto nos botões */
.btn i { margin-right: 6px; }

/* ALERTAS */
.alerta {
  border-radius: 8px;
  padding: 10px 15px;
  margin-bottom: 15px;
  font-size: 1.03rem;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  box-shadow: 0 1px 7px #e5e5e520;
}
.alerta.sucesso {
  background: #e2f7e9;
  color: #257a4a;
  border-left: 4px solid var(--success);
}
.alerta.erro {
  background: #ffeaea;
  color: #bb4747;
  border-left: 4px solid var(--danger);
}
/* Estilos para alertas detalhados com mais conteúdo */
.alerta-detalhado {
  display: block; /* Sobrescreve o display:flex do .alerta base para conteúdo em bloco */
  margin-top: 20px;
  margin-bottom: 20px;
}

.alerta-detalhado h4 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 1.1em; /* Um pouco maior que o texto normal do alerta */
  /* A cor será herdada de .alerta.erro ou .alerta.sucesso */
}

.alerta-detalhado h4 .fas {
  margin-right: 8px; /* Espaço entre o ícone e o texto do título */
}

.alerta-detalhado p {
  margin-bottom: 10px;
  line-height: 1.5; /* Melhora a legibilidade do parágrafo */
}

.alerta-detalhado ul {
  padding-left: 20px; /* Recuo padrão para listas */
  margin-bottom: 0; /* Remove margem inferior se for o último elemento */
  list-style-type: disc; /* Garante que os marcadores de lista sejam visíveis */
}
.alerta-detalhado li {
  margin-bottom: 5px; /* Espaçamento entre itens da lista */
  line-height: 1.4; /* Melhora a legibilidade dos itens da lista */
}
/* === Estilos para Submenu === */

/* Remove padding e marcadores da nova lista UL */
.menu-lateral ul {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
}

.menu-lateral ul li {
  width: 100%;
}

/* Esconde o submenu por defeito */
.menu-lateral .submenu {
  display: none;
  background-color: rgba(0,0,0,0.15); /* Cor de fundo para destacar */
  overflow: hidden;
}

/* Mostra o submenu quando a classe 'open' está presente */
.menu-lateral .submenu.open {
  display: block;
}

/* Estilo para os links do submenu */
.menu-lateral .submenu a {
  font-size: 0.9em; /* Fonte um pouco menor */
  padding-left: 45px; /* Indentação para o texto dos sub-itens */
}

/* Adiciona uma seta para indicar um submenu */
.menu-lateral .has-submenu > a::after {
  content: '▸'; /* Seta para a direita */
  float: right;
  margin-right: 15px;
  transition: transform 0.3s ease;
}

/* Gira a seta quando o submenu está ativo/aberto */
.menu-lateral .has-submenu.active > a::after {
  transform: rotate(90deg);
}

/* ---------- TABELAS BASE ---------- */
table {
  border-collapse: collapse;
  width: 100%;
  background: var(--card-bg, #fff);
  margin-bottom: 17px;
  border-radius: var(--card-radius, 10px); /* overflow: hidden removido para permitir que a tabela expanda */
  box-shadow: var(--card-shadow, 0 2px 12px #e1eafc33);
}
th, td {
  padding: 12px 13px;
  border-bottom: 1px solid var(--card-border, #e0ebf7);
  text-align: left;
  font-size: 1em;
  color: var(--text-main, #22324d);
  overflow-wrap: break-word; /* Permite que palavras longas nas células quebrem e previne o overflow */
}
th {
  background: var(--primary-light, #eaf2f9);
  color: var(--primary, #2274a5);
  font-size: 1.04em;
  font-weight: 700;
}
tr:last-child td {
  border-bottom: none;
}
tr:nth-child(even) td {
  background: var(--bg-table-even, #f6fafc);
  color: var(--text-main, #22324d);
}
tr:nth-child(odd) td {
  background: var(--card-bg, #fff);
}
tr:hover td {
  background: var(--primary-light, #e6f3fa);
  color: var(--primary-dark, #0c2945);
  transition: background .12s, color .12s;
}
/* RESPONSIVO */
@media (max-width: 1100px) {
  .cards-stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .menu-lateral { width: 56px; }
  .menu-lateral:not(.open) .txt { display: none; } /* Esconde texto se menu está colapsado e não explicitamente aberto para mobile */
  .dashboard-main { margin-left: 56px; padding-left: 3vw; padding-right: 3vw;}
  .container {
    padding: 10px 3vw 11px 3vw;
    overflow-x: auto; /* Adicionado para permitir scroll horizontal se o conteúdo (tabela) for largo demais */
  }
  .cards-stats { gap: 7px; }
}
@media (max-width: 650px) { /* Movido para manter a ordem de breakpoints e ajustado padding */
  .header-fixo { padding: 0 12px; font-size: .96em;}
  .dashboard-main { padding: 76px 2vw 28px 2vw;}
  .container { border-radius: 7px; padding: 4px 2vw 9px 2vw; }
  .cards-stats { grid-template-columns: 1fr; }
  .header-utilizador .user-type-label { /* Esconde o tipo de utilizador em telas menores */
    display: none;
  }
  table, th, td { font-size: .93em;}
}

/* SCROLL EM TABELA MOBILE */
@media (max-width: 520px) {
  table, thead, tbody, th, td, tr { display: block; width: 100%;}
  thead { display: none;}
  tr { margin-bottom: 12px; }
  td {
    border: none;
    position: relative;
    padding-left: 52%;
    min-height: 34px;
    font-size: .97em;
    overflow-wrap: break-word; /* Permite quebra de palavras longas no conteúdo da célula */
  }
  td:before {
    position: absolute;
    top: 8px; left: 9px; width: 46%; 
    white-space: normal; /* Permite quebra de linha nos rótulos */
    font-weight: bold;
    color: var(--primary-dark);
    content: attr(data-label);
    font-size: .97em;
  }
  .container {
    overflow-x: initial; /* Reseta o overflow-x quando a tabela empilha, pois não deve haver scroll horizontal do container */
  }
}

@media (max-width: 430px) { /* Mantido para overrides específicos de 430px */
  .header-fixo { height: 48px; font-size: .90em; }
  .dashboard-main { padding-top: 58px;}
   .header-logo img { /* Ajusta a altura do logo para caber no header reduzido */
    height: 30px; 
  }
  .container { border-radius: 4px; padding: 2px 2vw 5px 2vw; }
}

/* DARK MODE */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-main: #171e28;
    --bg-card: #232c39;
    --primary: #44bbef;
    --primary-dark: #2688c7;
    --primary-light: #1a232e;
    --text-main: #e5ecfa;
    --text-light: #fff;
    --success: #3dd98c;
    --danger: #ef7070;
    --bg-table-even: #20283c;

    /* Tokens de cartão (dark) */
    --card-bg: #232c39;
    --card-border: #2f3e52;
    --card-shadow: 0 6px 24px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.05);
    --card-hover-shadow: 0 10px 30px rgba(0,0,0,0.35);
    --text-strong: #ffffff;
    --text-secondary: #a0b3d0;

        /* Variáveis para .form-page-form inputs (Dark Mode Overrides) */
    --form-page-input-bg: #223049;
    --form-page-input-text: #eaf6fe;
    --form-page-input-border: #354f70; /* Consistente com outros inputs escuros */
    --form-page-input-focus-bg: #1f2a3b;
    --form-page-input-focus-border: var(--primary); /* var(--primary) já é temático para escuro aqui */
    --form-page-input-disabled-bg: #283448;
    --form-page-input-disabled-text: #8190a0;
    --form-page-input-disabled-border: #354f70;
  }
  body { background: var(--bg-main); color: var(--text-main);}
  .header-fixo { background: #222d39; color: var(--text-light);}
  .menu-lateral { background: #222d39; border-right-color: #27354c;}
  .menu-lateral a { color: #96b6d9; }
  .menu-lateral a.active, .menu-lateral a:hover { background: #2a3d5a; color: #65c7f5; border-left-color: var(--primary);}
  .dashboard-main { background: var(--bg-main);}
  .container { background: var(--bg-card); color: var(--text-main);}
  .legal-content h3 {
    color: var(--primary); /* Cor primária mais clara do dark mode */
    border-bottom-color: #27354c; /* Cor de borda escura consistente com o menu */
  }

  .card-stat {
    background: var(--card-bg);
    color: #d7e9fa;
    border: 1px solid var(--card-border);
    box-shadow: var(--card-shadow);
  }
  .stat-title { color: #cfe6ff; }
  .stat-value { color: #ffffff; }
  th { background: #203554; color: #77d4ff;}
  tr:nth-child(even) td { background: var(--bg-table-even);}
  .alerta.sucesso { background: #243c2a; color: #7fffa8; border-left-color: var(--success);}
  .alerta.erro { background: #533232; color: #ffd7d7; border-left-color: var(--danger);}
  input, select { background: #232c39; color: #f4faff; border-color: #355884; }
  input::placeholder, .form-section input::placeholder, .form-section select::placeholder { color: #8eb6d6; opacity: 1; }
}

/* Força tokens quando .dark-mode é aplicado manualmente no <body> */
body.dark-mode {
  --bg-main: #171e28;
  --bg-card: #232c39;
  --text-main: #e5ecfa;
  --card-bg: #232c39;
  --card-border: #2f3e52;
  --card-shadow: 0 6px 24px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.05);
  --card-hover-shadow: 0 10px 30px rgba(0,0,0,0.35);
  --text-strong: #ffffff;
  --text-secondary: #a0b3d0;
}
.filtro-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 400px;
  margin-bottom: 28px;
}
.filtro-form label {
  margin-bottom: 4px;
  font-weight: 600;
  color: var(--primary, #2274a5);
  display: block;
  user-select: none; -webkit-user-select: none; -ms-user-select: none; cursor: default;
}
.filtro-form input[type="date"],
.filtro-form input[type="text"],
.filtro-form select {
  width: 100%;
  padding: 10px 13px;
  border: 1px solid #bed3e7;
  border-radius: 7px;
  font-size: 1rem;
  background-color: #FFFFFF; /* Fundo branco explícito para tema claro */
  color: #22324d; /* Cor de texto escura explícita para tema claro */
  transition: border .13s, background .13s;
  height: 42px;
  box-sizing: border-box;
}

.filtro-form .btn,
.filtro-form button[type="submit"] {
  height: 42px;
  padding-top: 0;
  padding-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  font-size: 1.05rem;
}

 @media (prefers-color-scheme: dark) {
  .login-user-list h2 {
    color: #5cd8ff;
    font-weight: 900;
    font-size: 2em;
    letter-spacing: .01em;
    text-shadow: 0 2px 13px #145d857c;
    font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  }

  .utilizador-nome {
    color: #6feaff;
    font-weight: 900;
    font-size: 1.19em;
    letter-spacing: 0.02em;
    line-height: 1.16;
    text-shadow: 0 3px 18px #19c8ff36, 0 1.5px 7px #132e463a;
    font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  }

  .utilizador-tipo {
    color: #bbecff;
    font-weight: 500;
    font-size: 1em;
    opacity: 1;
    letter-spacing: .01em;
    font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
    text-shadow: 0 2px 10px #25b4ff16;
  }

  .utilizador-card input,
  .utilizador-card input::placeholder {
    color: #9ddaff !important;
    opacity: 1;
    font-size: 1em;
    font-weight: 400;
    letter-spacing: .01em;
    font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  }
}

.utilizador-card:hover {
  animation: userCardPulse 0.24s;
}
@keyframes userCardPulse {
  0%   { transform: scale(1.0);}
  55%  { transform: scale(1.055);}
  100% { transform: scale(1.045);}
}


@media (min-width: 700px) {
  .filtro-form {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: end;
    gap: 22px;  /* aumenta o gap para desktop */
    max-width: none;
  }
  .filtro-form > div {
    min-width: 150px;
    flex: 1 1 150px;
  }
}

  .filtro-form .btn,
  .filtro-form a.btn {
    width: auto;
    min-width: 110px;
    margin-top: 0;
  }

/* Modo escuro */
@media (prefers-color-scheme: dark) {
  .filtro-form input[type="date"],
  .filtro-form select {
    background: #283040 ;
    color: #eaf6fe ;
    border: 1px solid #446284;
  }
  .filtro-form label {
    color: #7fd6f8 ;
  }
  .filtro-form .btn {
   background: var(--primary); /* Usa a variável para consistência */
    color: var(--text-light);
  }
  .filtro-form a.btn {
    background: #213345;
    color: #7fd6f8;
    border: 1px solid var(--primary); /* Usa a variável para consistência */
  }
   /* Estilo para as opções do select no modo escuro para garantir visibilidade e consistência */
  .filtro-form select option {
   background: #283040 !important;
    color: #eaf6fe !important;
  }


}

/* ---------- DARK MODE PARA TABELAS ---------- */
@media (prefers-color-scheme: dark) {

  table {
    background: var(--card-bg, #233049);
    color: var(--text-main, #eaf6fe);
    box-shadow: var(--card-shadow, 0 2px 12px rgba(0,0,0,0.2));
  }
  th {
    background: var(--primary-light, #1b2739);
    color: var(--primary, #7fd6f8);
  }
  tr:nth-child(even) td {
    background: var(--bg-table-even, #20283c);
    color: var(--text-main, #eaf6fe);
  }
  tr:nth-child(odd) td {
    background: var(--card-bg, #233049);
    color: var(--text-main, #eaf6fe);
  }
  tr:hover td {
    background: var(--primary-light, #2c4267);
    color: var(--primary, #7fd6f8);
  }
  td, th {
    border-bottom: 1px solid var(--card-border, #304259);
  }
}
input, select, textarea {
  background: #f9fbfd;
  color: #22324d;
  border: 1px solid #bed3e7;
}
input:disabled, select:disabled, textarea:disabled {
  background: #e9ecef ;
  color: #bcc3ce ;
  opacity: 1 ;
}

/* Autofill Chrome/Safari */
input:-webkit-autofill,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px #f9fbfd inset !important;
  -webkit-text-fill-color: #22324d !important;
  box-shadow: 0 0 0 30px #f9fbfd inset !important;
  color: #22324d !important;
}
@media (prefers-color-scheme: dark) {
  input, select, textarea {
    background: #232c39;
    color: #eaf6fe;
    border: 1px solid #355884;
  }
  input:disabled, select:disabled, textarea:disabled {
    background: #283040 ;
    color: #79889a ;
    opacity: 1;
  }
  /* Autofill dark mode */
  input:-webkit-autofill,
  input:-webkit-autofill:focus,
  input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px #232c39 inset !important;
    -webkit-text-fill-color: #eaf6fe !important;
    box-shadow: 0 0 0 30px #232c39 inset !important;
    color: #eaf6fe !important;
  }

  /* Select dropdown: garantir fundo escuro nas opções */
  select { color-scheme: dark; }
  select option, select optgroup { background-color: #283040; color: #eaf6fe; }
  select option:checked, select option:hover { background-color: #355884; color: #eaf6fe; }
}

/* Regras equivalentes quando o modo escuro é forçado por classe */
body.dark-mode select { background: #232c39; color: #eaf6fe; border: 1px solid #355884; color-scheme: dark; }
body.dark-mode select option, body.dark-mode select optgroup { background-color: #283040; color: #eaf6fe; }
body.dark-mode select option:checked, body.dark-mode select option:hover { background-color: #355884; color: #eaf6fe; }
/* ---------- FORMULÁRIO IGUAL AO CONTAINER DE ENTRADAS/SAÍDAS ---------- */
.form-page-container {
  background: var(--bg-card, #232c39);
  border-radius: 13px;
  box-shadow: 0 2px 18px 0 rgba(40,110,180,0.12), 0 2px 8px 0 rgba(22,35,60,0.09);
  padding: 38px 32px 34px 32px;
  margin-bottom: 40px;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  border: 1px solid #5faee3;
  color: var(--text-main, #eaf6fe);
  position: relative;
  width: 100%;
}

.form-page-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  font-size: 1.10rem;
}

.form-page-form label {
  font-weight: 600;
  color: var(--primary, #2fc9ff);
  margin-bottom: 4px;
  font-size: 1.09em;
  display: block;
}

.form-page-form input[type="text"],
.form-page-form input[type="email"],
.form-page-form input[type="password"],
.form-page-form select {
  width: 100%;
  padding: 13px 14px;
  border-radius: 8px;
  font-size: 1.11rem;
  transition: border .13s, background .13s;
  outline: none;
   background: var(--form-page-input-bg);
  color: var(--form-page-input-text);
  border: 1.4px solid var(--form-page-input-border);
}

.form-page-form input:focus,
.form-page-form select:focus {
  border-color: var(--form-page-input-focus-border);
  background: var(--form-page-input-focus-bg);
}

.form-page-form input:disabled, .form-page-form select:disabled {
  opacity: 1;
  background: var(--form-page-input-disabled-bg);
  border-color: var(--form-page-input-disabled-border);
  color: var(--form-page-input-disabled-text);

}

.form-page-form .btn, .form-page-form button[type="submit"] {
  background: linear-gradient(90deg, #2ca1dd 60%, #00c8ff 100%);
  color: #fff;
  padding: 13px 0;
  border: none;
  border-radius: 8px;
  font-size: 1.14rem;
  font-weight: 800;
  box-shadow: 0 2px 12px rgba(34,116,165,0.13);
  cursor: pointer;
  transition: background .14s, box-shadow .13s, transform .13s;
  width: 100%;
  margin-top: 8px;
  letter-spacing: .15px;
}
.form-page-form .btn:hover, .form-page-form button[type="submit"]:hover {
  background: linear-gradient(90deg, #00c8ff 60%, #2ca1dd 100%);
  box-shadow: 0 8px 24px rgba(40,170,220,0.16);
  transform: translateY(-1px) scale(1.012);
}

/* Placeholder legível */
.form-page-form input::placeholder {
  color: #a5b9ce;
  opacity: 1;
  font-size: 1.04em;
}

/* Responsive */
@media (max-width: 900px) {
  .form-page-container {
    padding: 22px 4vw 18px 4vw;
    max-width: 99vw;
    border-radius: 9px;
  }
  .form-page-form input, .form-page-form select {
    font-size: 1rem;
    padding: 10px 7px;
    border-radius: 7px;
  }
  .form-page-form .btn {
    padding: 11px 0;
    font-size: 1rem;
    border-radius: 7px;
  }
  .form-page-form {
    gap: 14px;
    font-size: .98rem;
  }
}

/* Light mode só para este form */
@media (prefers-color-scheme: light), (prefers-color-scheme: no-preference) {
  .form-page-container {
    background: #fff;
    color: #22324d;
    border: 1px solid #bcd5ee;
    box-shadow: 0 10px 36px 0 rgba(40,110,180,0.07), 0 2px 8px 0 rgba(22,35,60,0.04);
    
  }
   /* Estilos para .dashboard-cards .card no modo claro */
  .dashboard-cards .card {
    background: var(--bg-card); /* Fundo claro padrão */
    color: var(--text-main);    /* Texto escuro padrão */
  }

  .login-user-list {
    background: linear-gradient(135deg, #f6fbff 70%, #eaf7ff 100%) !important;
    border-radius: 16px !important;
    box-shadow: 0 6px 36px #2274a51a, 0 1.5px 8px #bed3e710 !important;
    border: 1.4px solid #d3eafc !important;
  }
  .utilizador-card .avatar {
    background: #eaf7ff !important;
    border: 3.5px solid #23c0f7 !important;
  }
.utilizador-card:hover .utilizador-nome {
  color: #174d72;
  text-shadow: 0 1.5px 8px #23c0f71a;
  transition: color .13s, text-shadow .16s;
}
.utilizador-card:hover {
  animation: userCardPulse 0.24s;
}
@keyframes userCardPulse {
  0%   { transform: scale(1.0);}
  55%  { transform: scale(1.055);}
  100% { transform: scale(1.045);}
}
.login-user-list h2 {
  color: #1970b6;  /* azul principal escuro, forte */
  font-weight: 900;
  font-size: 2em;
  letter-spacing: .01em;
  text-shadow: 0 1px 6px #e6f3fa;
}

.utilizador-nome {
  color: #1485cc;  /* tom azul mais escuro para destacar */
  font-weight: 800;
  font-size: 1.14em;
  text-shadow: 0 1.5px 6px #b3e5fc33;
}

.utilizador-tipo {
  color: #7ba1c7; /* azul acinzentado, bem legível */
  font-size: 1em;
  font-weight: 500;
  opacity: 1;
  letter-spacing: .01em;
}
.utilizador-card input::placeholder {
  color: #9db2c7 !important;  /* Mais escuro que cinzento claro */
  opacity: 1;
  font-size: 1em;
  font-weight: 400;
  letter-spacing: .01em;
}
.utilizador-tipo {
  color: #829bb3;  /* azul cinza claro, mas bem visível */
  font-weight: 500;
  font-size: 1em;
  opacity: 0.96;
}
.utilizador-nome, .login-user-list h2 {
  letter-spacing: 0.015em;
  line-height: 1.16;
}
.login-user-list, .utilizador-card {
  font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
}

}

.form-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 24px;
  align-items: start;
}

.form-2col .col {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.form-2col .col-full {
  grid-column: 1 / 3;
  margin-top: 14px;
}

.form-2col label {
  font-weight: 700;
  color: #33c6fe;
  margin-bottom: 2px;
  font-size: 1.12em;
  letter-spacing: 0.02em;
}

.form-2col input,
.form-2col select {
  width: 100%;
  box-sizing: border-box;
  /* nada de margin lateral aqui */
}

.form-2col input:focus,
.form-2col select:focus {
  border-color: #2fc9ff;
}

/* Botão ocupa duas colunas */
.form-2col .btn {
  width: 100%;
  font-size: 1.08em;
  padding: 15px 0;
  border-radius: 8px;
  margin-top: 0;
  font-weight: 800;
}


/* Responsive para mobile/tablet */
@media (max-width: 800px) {
  .form-2col {
    grid-template-columns: 1fr;
    gap: 16px 0;
  }
  .form-2col .col-full {
    grid-column: auto;
    margin-top: 10px;
  }
  .form-2col .btn {
    font-size: 1em;
    padding: 13px 0;
    border-radius: 7px;
  }
  .form-2col label {
    font-size: 1em;
  }
  .form-2col input, .form-2col select {
    font-size: 1em;
    padding: 11px 8px;
    border-radius: 7px;
  }
}
/* Container do alerta */
.container-alerta {
  background: rgba(35, 48, 73, 0.92);   /* Igual ao .container do dashboard */
  box-shadow: 0 6px 40px 0 rgba(40,110,180,0.13), 0 2px 8px 0 rgba(22,35,60,0.11);
  padding: 38px 32px 34px 32px;
  margin-bottom: 48px;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  border: 1.5px solid #ff4c4c;         /* Mantém vermelho para destaque */
  color: #ff3737;
  position: relative;
  /* Glass */
  backdrop-filter: blur(7px) saturate(1.4);
  -webkit-backdrop-filter: blur(7px) saturate(1.4);
  transition: box-shadow .22s, background .22s;
}


.container-alerta h3 {
  color: #ff4c4c;
  font-weight: 800;
  margin-top: 0;
}

.container-alerta ul {
  margin-top: 19px;
}

.container-alerta ul li {
  color: #ff2d2d;
  font-weight: 700;
  margin-bottom: 11px;
  letter-spacing: 0.02em;
  font-size: 1.09em;
  list-style: disc inside;
}

.login-numerico-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 28px 32px 24px 32px;
  justify-content: center;
}

.login-numerico-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  margin-top: 20px;
  width: 100%;
  min-height: 110px;
}

.login-numerico-header .avatar {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: #cfd6de;
  border: 3.5px solid #23c0f7;
  box-shadow: 0 2px 14px #343e5015;
  margin-bottom: 9px;
}

.login-numerico-header .nome-utilizador {
  font-weight: 900;
  color: #23c0f7;
  font-size: 1.25em;
  letter-spacing: 0.02em;
  text-align: center;
  text-shadow: 0 2px 10px #0af6ff12;
  margin-top: 0;
}

.pin-input {
  width: 100%;
  font-size: 1.55em;
  padding: 12px 14px;
  border: 1.5px solid #77c8ee;
  border-radius: 11px;
  color: #3ac2ff;
  text-align: center;
  outline: none;
  margin-bottom: 22px;
  margin-top: 2px;
  box-sizing: border-box;
  letter-spacing: 0.24em;
  font-weight: 700;
  transition: box-shadow .16s;
  box-shadow: 0 3px 18px #39bbf227;
}

.pin-input:focus {
  border-color: #3ac2ff;
  box-shadow: 0 4px 16px #3ac2ff22;
}

.teclado-numerico {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 17px;
  margin-bottom: 22px;
}

.teclado-btn {
  background: linear-gradient(90deg, #28b6f6 60%, #20c3ee 100%);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 1.36em;
  font-weight: 900;
  box-shadow: 0 2.5px 9px #1e7ca62a, 0 1.2px 2px #0b203515;
  padding: 18px 0 14px 0;
  transition: background 0.13s, box-shadow 0.17s, color 0.11s;
  cursor: pointer;
  outline: none;
  user-select: none;
}
.teclado-btn:hover,
.teclado-btn:active,
.teclado-btn:focus {
  background: linear-gradient(90deg, #2293d4 55%, #1ba9c7 100%);
  color: #fff;
  box-shadow: 0 3px 14px #2293d455, 0 1.5px 2px #0b203512;
}

.btn-row {
  display: flex;
  gap: 22px;
  width: 100%;
  margin-bottom: 9px;
}

.btn-confirm,
.btn-cancel {
  flex: 1;
  font-size: 2.2em;
  padding: 10px 0 7px 0;
  border-radius: 11px;
  border: none;
  font-weight: bold;
  cursor: pointer;
  transition: background 0.13s, box-shadow 0.13s;
  box-shadow: 0 2px 12px #189d4362, 0 1px 2px #0002;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-confirm {
  background: linear-gradient(90deg, #3ef189, #2edeb2 96%);
  color: #fff;
}
.btn-cancel {
  background: linear-gradient(90deg, #f24444, #da3d5e 98%);
  color: #fff;
}
.btn-confirm:hover { background: #19a453; }
.btn-cancel:hover { background: #be285c; }

@media (max-width: 600px) {
  .login-numerico-container {
    max-width: 98vw;
    min-width: unset;
    padding: 7vw 2vw 10vw 2vw;
  }
  .pin-input { font-size: 1.18em; }
  .teclado-btn { font-size: 1em; padding: 11px 0 10px 0;}
  .btn-confirm, .btn-cancel { font-size: 1.3em;}
}
.login-user-list {
  background: linear-gradient(135deg, #262f3d 80%, #223242 100%);
  border-radius: 16px;
  box-shadow: 0 8px 42px #1820402a;
  margin: 54px auto 0 auto;
  padding: 38px 24px 36px 24px;
  border: 1.4px solid #b6ecff29;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.login-user-list h2 {
  font-size: 2em;
  color: #23c0f7;
  font-weight: 900;
  margin-bottom: 35px;
  text-align: center;
  letter-spacing: 0.01em;
  text-shadow: 0 3px 18px #24c0ff1a;
}

.utilizadores-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 38px;
  width: 100%;
  margin-bottom: 20px;
}

.utilizador-card .avatar {
  width: 66px; height: 66px;
  border-radius: 50%;
  background: #f3fbff;
  border: 3.5px solid #23c0f7;
  margin-top: 20px; /* Adicionado para criar espaço para a etiqueta da reparação */
  margin-bottom: 16px;
  box-shadow: 0 3px 15px #23c0f733;
}

.utilizador-nome {
  font-weight: 900;
  color: #23c0f7;
  font-size: 1.18em;
  margin-bottom: 0;
  letter-spacing: 0.02em;
  text-shadow: 0 3px 8px #24c0ff15;
}
.utilizador-tipo {
  color: #d1e9f9;
  font-size: 1.01em;
  font-weight: 500;
  margin-top: 1px;
  opacity: .92;
}

@media (max-width: 650px) {
  .login-user-list { max-width: 99vw; padding: 6vw 2vw 8vw 2vw;}
  .utilizadores-grid { gap: 21px;}
  .utilizador-card { min-width: 40vw; padding: 5vw 2vw 2vw 2vw; }
  .utilizador-card .avatar { width: 16vw; height: 16vw; min-width:44px; min-height:44px; }
}
.login-header {
  text-align: center;
  margin: 42px auto 0 auto;
  padding-bottom: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  animation: fadeInDown 1.1s cubic-bezier(.42,1.4,.44,.96);
}

.empresa-logo {
  width: 250px;
  height: 96px;
  object-fit: contain;
  margin-bottom: 10px;
  filter: drop-shadow(0 2px 18px #1caaff1b);
  transition: transform .19s cubic-bezier(.4,1.6,.55,.9);
}
.empresa-logo:hover {
  transform: scale(1.07) rotate(-2deg);
}

.programa-nome {
  font-size: 2.1em;
  font-weight: 900;
  color: #2fd2ff;
  letter-spacing: .01em;
  margin-bottom: 7px;
  text-shadow: 0 3px 20px #15a7e830, 0 1px 0px #fff3;
  font-family: 'Segoe UI', 'Arial', sans-serif;
  animation: fadeIn .8s .12s backwards;
}

/* Pequena animação premium */
@keyframes fadeInDown {
  0% { opacity: 0; transform: translateY(-38px);}
  100% { opacity: 1; transform: none;}
}
@keyframes fadeIn {
  from { opacity: 0;}
  to { opacity: 1;}
}

@media (max-width: 600px) {
  .empresa-logo { width: 150px; height: auto; }
  .programa-nome { font-size: 1.35em;}
}
.avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #cfd6de;
  border: 2.5px solid #e4e9f7;
  object-fit: cover;
  box-shadow: 0 2px 14px #343e5022;
}
.tipo-utilizador {
  color: #7ee5fd;
  font-size: 1.05em;
  margin-top: 2px;
  text-align: center;
  font-weight: 400;
  letter-spacing: .01em;
}
.btn-editar, .btn-apagar {
  display: inline-block;
  border: none;
  border-radius: 5px;
  padding: 6px 18px;
  font-size: 1em;
  font-weight: 600;
  margin-right: 7px;
  margin-bottom: 2px;
  cursor: pointer;
  transition: background .13s;
  text-decoration: none;
}

.btn-editar {
  background: #2196f3;
  color: #fff;
}
.btn-editar:hover {
  background: #37dcff;
}

.btn-demitir {
  background: #ff9f43;
  color: #fff;
  border-radius: 5px;
  padding: 6px 18px;
  font-size: 1em;
  font-weight: 600;
  margin-left: 4px;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s;
}
.btn-demitir:hover {
  background: #ff6300;
  color: #fff;
}
.btn-readmitir {
  background: var(--warning);
  color: #fff;
  border: none;
  border-radius: 5px;
  padding: 6px 18px;
  font-size: 1em;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s;
}
.desativado {
  color: #999;
  font-size: 1em;
  font-weight: 500;
  margin-left: 10px;
}

.registo-main {
    max-width: 1100px;
    margin: 32px auto 0 auto;
    padding: 30px 32px;
    background: #232b34;
    border-radius: 16px;
    box-shadow: 0 6px 32px #0008;
}

.registo-title {
    font-size: 2.1rem;
    color: #3dc6ff;
    font-weight: 700;
    margin-bottom: 18px;
    letter-spacing: 1px;
}

.registo-btns {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 24px;
}
.registo-btn {
    padding: 20px 0;
    font-size: 1.4rem;
    font-weight: bold;
    border-radius: 12px;
    border: none;
    transition: background .14s, box-shadow .14s;
    cursor: pointer;
    box-shadow: 0 2px 10px #202b3c22;
}
.registo-btn.entrada, .registo-btn.pausa-inicio, .registo-btn.pausa-fim {
    background: linear-gradient(90deg, #3dc6ff 70%, #30baff 100%);
    color: #fff;
}
.registo-btn.entrada:hover,
.registo-btn.pausa-inicio:hover,
.registo-btn.pausa-fim:hover {
    filter: brightness(1.15);
    box-shadow: 0 4px 24px #3dc6ff33;
}
.registo-btn.saida {
    background: linear-gradient(90deg, #fa5050 60%, #ff8181 100%);
    color: #fff;
}
.registo-btn.saida:hover {
    filter: brightness(1.1);
    box-shadow: 0 4px 24px #fa505055;
}

.registo-sep {
    height: 1px;
    background: #353f4c;
    margin: 30px 0 18px 0;
    border-radius: 2px;
}

.registos-titulo {
    font-size: 1.3rem;
    color: #3dc6ff;
    font-weight: 700;
    margin-bottom: 10px;
}

.registo-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border-radius: var(--card-radius, 10px);
    overflow: hidden;
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    box-shadow: var(--card-shadow);
}
.registo-table th, .registo-table td {
    padding: 13px 16px;
    text-align: left;
}
.registo-table th {
    background: var(--primary-light);
    color: var(--primary);
    font-weight: 700;
    border-bottom: 1px solid var(--card-border);
}
.registo-table tr {
    background: var(--card-bg);
}
.registo-table tr:nth-child(even) {
    background: var(--bg-table-even);
}
.registo-ponto-form {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 28px;
}



.registo-ponto-form .btn-block {
    width: 100%;
    padding: 30px 0;
    font-size: 1.2rem;
    min-width: 0;
    border-radius: 12px;
    font-weight: 600;
    color: #fff;
    border: none;
    transition: background 0.2s, transform 0.15s;
    box-shadow: 0 2px 8px 0 rgba(0,0,0,0.10);
    cursor: pointer;
    outline: none;
}

.registo-ponto-form .btn-block:active {
    transform: scale(0.98);
}

.registo-ponto-form .btn-block:hover,
.registo-ponto-form .btn-block:focus {
    background: linear-gradient(90deg, #2e90c6 70%, #1b6e97 100%);
    box-shadow: 0 4px 20px #38b6ff88;
}


@media (max-width: 900px) {
  .registo-ponto-form {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 500px) {
  .dashboard-main { padding: 70px 3vw 20px 3vw; }
  .container { padding: 7px 3vw 7px 3vw; }
  .card-stat, .cards-stats { padding: 9px; }
  .registo-table th, .registo-table td { padding: 7px 5px; font-size: 0.96em; }
  .registo-table th, .registo-table td {
    white-space: nowrap;
  }
}



.registo-ponto-form .btn-entrada { background: #29c4f0; color: #fff; }
.registo-ponto-form .btn-saida { background: #e84545; color:#fff; }
.registo-ponto-form .btn-pausa { background: #ffd600; color: #fff; }



.tabela-registos th, .tabela-registos td {
    text-align: center;
    font-size: 1.07em;
    padding: 14px 10px;
    border-bottom: 1px solid var(--card-border);
}
.tabela-registos th {
    background: var(--primary-light);
    color: var(--primary);
    font-weight: 800;
}
/*.tabela-registos tr:nth-child(even) td {
    background: #233047;
}*/
.tabela-registos tr {
    background: var(--card-bg);
}
.tabela-registos tr:nth-child(even) td { background: var(--bg-table-even); }
.tabela-registos tr:hover td {
    background: var(--primary-light);
    color: var(--text-strong);
    transition: .18s;
}
.tipo-entrada { color: #29c4f0; font-weight: bold; }
.tipo-saida { color: #e84545; font-weight: bold; }
.tipo-pausa { color: #ffd600; font-weight: bold; }
.sucesso { background: #c5f7d3; color: #198754; border-radius: 8px; padding: 10px; margin: 10px 0; }
.nenhum-registo { color: #ccc; text-align: center; margin-top: 20px; }


.page-title { font-size: 2em; margin-bottom: 15px; }
    .success-message { color: #27e227; font-weight: 500; margin-bottom: 15px;}
    .reparacao-form, .form-row { display: flex; gap: 16px; margin-bottom: 12px; flex-wrap: wrap;}
    .reparacao-form input { width: 220px; }
    .btn { padding: 12px 30px; font-size: 1em; border-radius: 7px; border: 0; cursor: pointer; }
    .btn.iniciar { background: #29c4f0; color: #fff;}
    .btn.terminar { background: linear-gradient(90deg,#d93e3e 70%,#ff6363 100%); color: #fff;}
    .btn.pausar { background: #ffe082; color: #252a36;}
    .btn.retomar { background: #6ee780; color: #151d14;}
    table { width: 100%; border-radius: 10px; background: #202a39; color: #e6f1fa; border-collapse: collapse; margin-top:12px;}
    th, td { padding: 10px 7px; text-align: center; }
    th { background: #253044; color: #5ad6ff; font-weight: 600;}
    tbody tr:nth-child(even) { background:#222e40;}
    .cronometro { font-family: 'Inter', monospace; font-size: 1.2em; font-weight: 700; color: #5ad6ff; }
    .estado-pausa { color: #e84545; font-weight: bold; }
    @media (max-width:800px) {
      .reparacao-form input { width: 100%; }
      th, td { padding:7px 4px;}
    }

     .paginacao-container .btn {
    background: #243042;
    color: #e4f7ff;
    border-radius: 7px;
    padding: 6px 16px;
    font-weight: 600;
    text-decoration: none;
    margin: 0 2px;
    transition: .2s;
    border: 0;
    cursor: pointer;
}
.paginacao-container .btn.active,
    .paginacao-container .btn:active {
    background: #27d2f8;
    color: #07374c;
    box-shadow: 0 0 0 2px #27d2f833;
    cursor: default;
}
 .paginacao-container .btn:hover:not(.active) {
    background: #176591;
    color: #fff;
}
@media (min-width: 1280px) {
  .container { max-width: 1480px; }
}
@media (max-width: 450px) {
  html, body {
    font-size: 14px ;
  }
  .header-fixo {
    height: 46px ;
    padding: 0 5px ;
    font-size: 0.94em;
  }
  .header-logo img { /* Ajuste fino para o logo no breakpoint de 450px, se necessário */
    font-size: 0.94em;
}

  .menu-lateral {
    width: 45px ;
    min-width: 45px ;
  }
  .dashboard-main {
    margin-left: 0 ;
    padding: 52px 2vw 16px 2vw ;
  }
  .container, .form-page-container {
    padding: 9px 1vw 9px 1vw ;
    max-width: 99vw ;
    border-radius: 6px ;
    box-shadow: 0 2px 12px #202a39bb;
  }
  h2, h3, .page-title, .registo-title {
    font-size: 1.12em ;
    margin-bottom: 11px ;
  }
  .cards-stats {
    grid-template-columns: 1fr ;
    gap: 7px ;
  }
  /* Formulários */
  .form-row, .reparacao-form {
    flex-direction: column ;
    gap: 7px ;
  }
  .form-group input, .form-group textarea, .form-page-form input, .form-page-form select {
    font-size: 1em ;
    padding: 8px 7px ;
    border-radius: 6px ;
    min-width: 0 ;
  }
  .registo-ponto-form {
    grid-template-columns: 1fr;
    gap: 12px ;
  }
  .registo-ponto-form .btn-block,
  button, .btn {
    font-size: 1em ;
    padding: 16px 0 ;
    border-radius: 7px ;
  }
  .tabela-registos, table, .registo-table {
    font-size: 0.95em ;
    border-radius: 6px ;
    min-width: 0 ;
  }
  th { /* Aplicar padding geral aos cabeçalhos */
    padding: 8px 2px;
    font-size: 1em ;
  }
  td { /* Para as células de dados, apenas ajustar o font-size se necessário, preservando o padding-left da regra de 520px para empilhamento */
    font-size: 1em;
  }
  /* Tabelas em stack (scroll horizontal se necessário) */
  .container, .form-page-container {
    overflow-x: auto ;
  }
  /* Login PIN */
  .login-numerico-container {
    padding: 6vw 1vw 8vw 1vw ;
    max-width: 98vw ;
  }
  .pin-input {
    font-size: 1.05em ;
    padding: 8px 7px ;
  }
  .teclado-btn {
    font-size: 0.93em ;
    padding: 10px 0 ;
    border-radius: 8px ;
  }
  .utilizadores-grid {
    gap: 11px ;
  }
  .utilizador-card {
    min-width: 74vw ;
    max-width: 98vw ;
    padding: 7vw 2vw 2vw 2vw ;
  }
   /* Ajustes para paginação em telas muito pequenas */
  .paginacao-container {
    gap: 4px; /* Reduz o espaçamento entre os botões */
  }
  .paginacao-container .btn {
    padding: 5px 10px; /* Reduz o padding dos botões */
    font-size: 0.9em; /* Reduz o tamanho da fonte dos botões */
  }
}
.menu-bottom-brand {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 23px 0 11px 0;
  width: 100%;
  font-family: 'Montserrat', Arial, sans-serif;
}
.menu-app-name {
  font-size: 1.45em;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #39d1ff;
  display: flex;
  align-items: center;
}
.menu-app-plus {
  color: #ffd600;
  font-size: 1.1em;
  margin-left: 1px;
  font-weight: 900;
}
.menu-app-by {
  font-size: 1em;
  color: var(--text-muted);
  margin-top: 2px;
  font-weight: 500;
  letter-spacing: .02em;
}
.menu-app-infor {
  color: var(--text-muted);
  font-weight: 700;
}
.menu-app-q {
  color: #ff9800;
  font-weight: 900;
  font-size: 1.07em;
}
@media (prefers-color-scheme: dark) {
  .menu-bottom-brand { border-top: 1px solid #304259; }
  .menu-app-name { color: #44bbef; }
  .menu-app-plus { color: #ffd600; }
  .menu-app-by { color: #fff; }
  .menu-app-infor { color: #fff; }
  
}

/* === Estilos para o Modal de Termos Legais === */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1050;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
}

.modal-termos {
  background: var(--card-bg, var(--bg-card, #fff));
  color: var(--text-main, #22324d);
  border-radius: var(--card-radius, 12px);
  box-shadow: var(--card-shadow, 0 5px 25px rgba(0,0,0,0.2));
  border: 1px solid var(--card-border, #e0ebf7);
  width: 90%;
  max-width: 800px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-termos-header {
  padding: 16px 24px;
  border-bottom: 1px solid var(--card-border, #e0ebf7);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--primary, #2274a5);
}

.modal-termos-body {
  padding: 24px;
  overflow-y: auto;
  flex-grow: 1;
}

.modal-termos-body h2 { /* Título de cada documento dentro do modal */
    font-size: 1.5rem;
    color: var(--primary-dark);
    margin-bottom: 1rem;
}

.modal-termos-footer {
  padding: 16px 24px;
  border-top: 1px solid var(--card-border, #e0ebf7);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg-main, #f3f7fa);
}

.modal-termos-footer .checkbox-container {
  display: flex;
  align-items: center;
  gap: 8px;
}
.modal-termos-footer .checkbox-container label {
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
}
.modal-termos-footer .btn[disabled] {
  background: #a0b4c8;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

@media (prefers-color-scheme: dark) {
  .modal-termos-header { border-bottom-color: var(--card-border, #2f3e52); }
  .modal-termos-footer { border-top-color: var(--card-border, #2f3e52); background: #1e2632; }
  .modal-termos-footer .btn[disabled] { background: #4a5c75; }
  .modal-termos-body h2 { color: var(--primary); }
}

/* Estilos para Dashboard Admin (admin.php) */
.dashboard-cards {
  display: flex;
  gap: 1.5rem; /* Ajustado de 2rem */
  margin: 1.5rem 0; /* Ajustado de 2rem */
  flex-wrap: wrap;
}
.dashboard-cards .card { /* Tornar semelhantes aos .stat-card das Férias */
  background: var(--card-bg);
  color: var(--text-strong);
  border: 1px solid var(--card-border);
  border-radius: calc(var(--card-radius) - 2px);
  box-shadow: var(--card-shadow), inset 0 0 0 1px rgba(255,255,255,0.04);
  padding: 1.2rem 1rem;
  min-width: 150px;
  text-align: center;
  flex: 1 1 170px;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.dashboard-cards .card:hover {
  transform: translateY(-2px);
  box-shadow: var(--card-hover-shadow, 0 6px 20px rgba(0,0,0,.18));
}
.dashboard-cards .card h3 { /* Label semelhante a .stat-card-label */
  margin: 0 0 6px 0;
  color: var(--primary);
  font-size: 1.06rem;
  font-weight: 800;
}
.dashboard-cards .card span { /* Valor semelhante a .stat-card-value */
  display: block;
  margin-top: .25rem;
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--text-strong);
}
.dashboard-graphs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem; /* Ajustado */
}
.dashboard-graphs > div { background: var(--card-bg); border: 1px solid var(--card-border); box-shadow: var(--card-shadow); border-radius: var(--card-radius); padding:1.2rem 1.5rem; }
.dashboard-graphs canvas { background:transparent; border-radius:8px; margin:1rem 0; }
@media (max-width:900px) {.dashboard-graphs { grid-template-columns:1fr; }}
.mesano-label { /* Corrigido: seletor para o span dentro do h2 */
  color:var(--accent, #6df); 
  font-size:1rem; 
  margin-left: 8px;
}

/* Media query para menu lateral mobile - agrupada aqui para melhor organização */
@media (max-width: 700px) { /* Ajustado de 900px para menu colapsado para 700px para menu off-canvas */
  .menu-lateral {
    position: fixed; /* Garante que é fixed para sobrepor */
    left: -210px; /* Começa fora da tela */
    top: 64px; /* Abaixo do header */
    width: 210px; /* Largura do menu quando aberto */
    z-index: 1001; /* Acima do overlay e conteúdo */
    transition: left 0.27s cubic-bezier(.8,.1,.22,1.2);
  }
  .menu-lateral.open { left: 0; } /* Mostra o menu */
  .dashboard-main { margin-left: 0; } /* Conteúdo principal ocupa tudo quando menu está escondido */
  .menu-mobile-toggle { display: block; } /* Mostra o botão de toggle */
}

/* ... outros estilos ... */

.btn-limpar-filtros {
  background: #e7f3fa; /* Cor de fundo clara */
  color: #1b476d; /* Cor de texto escura */
  border: 1px solid #c5d9e8; /* Borda suave */
  text-decoration: none; /* garante ausência de sublinhado para anchors */
}
.btn-limpar-filtros:hover {
  background: #dceaf5;
  color: #133a57;
}

.paginacao-container {
  margin: 24px 0;
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap; /* Para melhor responsividade se houver muitos botões de página */
}

/* ... restantes estilos ... */
/* Para index.php */
.login-numerico-container {
  display: none;
  max-width: 420px;
  margin: 48px auto 0 auto;
}
.pin-dots-container {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
  gap: 5px;
}
.login-numerico-container .pin-input { /* Especificidade para o input de PIN nesta secção */
    margin-bottom: 18px;
}
.login-numerico-container .teclado-btn { /* Especificidade para os botões do teclado nesta secção */
    font-size: 1.15em;
}
.login-numerico-container .btn-row {
    margin-top: 9px;
}

/* Para reparacoes.php */
.form-inline {
  display: inline;
}
.form-no-margin {
  margin: 0;
}

/* Para paginação em registos_entrada_saida.php e registos_reparacoes.php */
.paginacao-reticencias {
  padding: 0 5px;
}

/* --- Toolbar de filtros (admin_ferias) --- */
.table-toolbar .filter-form {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;              /* linhas x colunas */
  align-items: end;             /* alinha ao fundo para uniformizar baseline */
}
.table-toolbar .filter-form .form-group {
  display: flex;
  flex-direction: column;
  margin: 0;                    /* retira margens verticais excessivas */
  min-width: 180px;
}
.table-toolbar .filter-form .form-group label { margin-bottom: 6px; }
.table-toolbar .filter-form input[type="date"],
.table-toolbar .filter-form input[type="text"],
.table-toolbar .filter-form select {
  width: 100%;
  height: 42px;
  padding: 10px 13px;
  border: 1px solid #bed3e7;
  border-radius: 7px;
  font-size: 1rem;
  box-sizing: border-box;
}
.table-toolbar .filter-form input[type="checkbox"] {
  width: 18px; height: 18px;
}
.table-toolbar .filter-form .btn,
.table-toolbar .filter-form button[type="submit"] {
  align-self: end;              /* alinha botão com a linha dos campos */
  height: 42px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* Alinhamento horizontal do checkbox + label (sem estilos inline) */
.table-toolbar .filter-form .form-group.checkbox-inline {
  flex-direction: row; align-items: center; gap: 8px; min-width: unset;
}

/* Grupo de ações (botões) lado a lado e alinhados pela base */
.table-toolbar .filter-form .form-group.actions {
  flex-direction: row;
  align-items: center;
  gap: 10px;
  min-width: unset;
}

/* Responsivo: otimiza espaçamentos em ecrãs mais pequenos */
@media (max-width: 768px) {
  /* Em tablets/telemóveis, usar layout em coluna para evitar "saltos" verticais */
  .table-toolbar .filter-form {
    display: grid;
    grid-template-columns: 1fr;   /* uma coluna para evitar desalinhamentos */
    gap: 10px;                    /* espaçamento compacto e consistente */
    align-items: start;            /* evita espaços verticais entre grupos */
  }
  .table-toolbar .filter-form .form-group { min-width: 0; }
  .table-toolbar .filter-form .btn,
  .table-toolbar .filter-form button[type="submit"] { height: 40px; }
}

@media (max-width: 480px) {
  .container { padding: 20px 14px; }
  .panel { padding: 12px; }
  .panel-header { padding: 8px 10px 10px 10px; margin: -12px -12px 10px -12px; }
  .table-toolbar .filter-form { gap: 8px 10px; }
  .table-toolbar .filter-form .form-group label { margin-bottom: 4px; }
  .table-toolbar .filter-form input[type="date"],
  .table-toolbar .filter-form input[type="text"],
  .table-toolbar .filter-form select { height: 40px; }
}

/* Para editar_utilizador.php */
.label-nota {
  font-weight: normal;
  color: #aaa; /* Considerar usar uma variável CSS se esta cor for reutilizada */
}
@media (prefers-color-scheme: dark) {
  .label-nota {
    color: #777; /* Ajustar para dark mode */
  }
}

.nova-reparacao {
  margin-bottom: 28px;
}

/* --- Estilos da Legenda de Cores --- */
.color-legend {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-bottom: 30px;
    padding: 10px;
    background-color: #f8f9fa;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    flex-wrap: wrap; /* Para ecrãs mais pequenos */
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.legend-dot {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    border: 1px solid rgba(0,0,0,0.1);
    box-shadow: 0 1px 2px rgba(0,0,0,0.1);
}

.legend-text {
    font-size: 0.9em;
    font-weight: 500;
    color: #495057;
}

/* Aplicar as cores aos pontos da legenda */
.legend-dot.status-entrada { background-color: #28a745; }
.legend-dot.status-pausa { background-color: #ffc107; }
.legend-dot.status-reparacao { background-color: #007bff; }
.legend-dot.status-ausente { background-color: #dc3545; }


/* Secção de formulário ou "cartão" */
.form-section {
    background-color: var(--background-color-light);
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 2rem;
    border: 1px solid var(--border-color);
}

/* Quando uma .form-section vive dentro de um .panel, não precisamos de novo “cartão” interno */
.panel .form-section {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0 0 1rem 0; /* pequeno espaçamento inferior apenas */
}
.panel .form-section h3 {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: .75rem;
}

.form-section h3 {
    margin-top: 0;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 10px;
    margin-bottom: 20px;
    font-weight: 500;
    display: flex;
    align-items: center;
}

.form-section h3 i {
    margin-right: 10px;
    color: var(--primary-color);
}

/* Garante que a tabela é responsiva em ecrãs pequenos */
.table-responsive {
    overflow-x: auto;
}

/* ==========================================================================
   Estilos dos Cartões de Utilizador (Login)
   ========================================================================== */

/* 1. Estrutura Base do Cartão (comum a todos os modos) */
.utilizador-card {
    border-radius: 20px;
    padding: 30px 32px 18px 32px;
    text-align: center;
    cursor: pointer;
    border: 1.6px solid transparent; /* Borda base transparente */
    border-left-width: 5px; /* Espaço para a cor de status */
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 140px;
    max-width: 175px;
    transition: transform 0.14s, box-shadow 0.16s, border-color 0.15s, background-color 0.3s;
    user-select: none;
    position: relative;
}

.utilizador-card:hover,
.utilizador-card:focus {
    transform: translateY(-4px) scale(1.06);
    border-color: #23c0f7;
    box-shadow: 0 7px 38px #24e3d7aa, 0 3px 16px #24b0e944;
}

/* 2. Estilos para Modo Claro */
@media (prefers-color-scheme: light), (prefers-color-scheme: no-preference) {
    /* O cartão de admin (sem classe de status) fica branco */
    .utilizador-card {
        background-color: #fff;
        border-color: #e3eaf6;
        border-left-color: #e3eaf6; /* Borda esquerda neutra por defeito */
        box-shadow: 0 3px 18px #2274a510, 0 1.5px 8px #e7f3fa10;
    }

    /* Cores para os status dos empregados */
    .utilizador-card.status-entrada {
        background-color: #f6ffed;
        border-left-color: #52c41a;
    }
    .utilizador-card.status-reparacao {
        background-color: #e6f7ff;
        border-left-color: #1890ff;
    }
    .utilizador-card.status-pausa {
        background-color: #fffbe6;
        border-left-color: #faad14;
    }
    .utilizador-card.status-ausente {
        background-color: #fff1f0;
        border-left-color: #f5222d;
    }
}

/* 3. Estilos para Modo Escuro */
@media (prefers-color-scheme: dark) {
    /* O cartão de admin (sem classe de status) fica com o fundo escuro padrão */
    .utilizador-card {
        background: linear-gradient(135deg, #242f44 85%, #263b59 100%);
        border-color: transparent;
        border-left-color: transparent;
    }

    /* Cores para os status dos empregados */
    .utilizador-card.status-entrada {
        background: linear-gradient(135deg, #2b442d 85%, #2f4b31 100%);
        border-left-color: #52c41a;
    }
    .utilizador-card.status-reparacao {
        background: linear-gradient(135deg, #243a50 85%, #263b59 100%);
        border-left-color: #1890ff;
    }
    .utilizador-card.status-pausa {
        background: linear-gradient(135deg, #544524 85%, #594b28 100%);
        border-left-color: #faad14;
    }
    .utilizador-card.status-ausente {
        background: linear-gradient(135deg, #4d2c2f 85%, #533033 100%);
        border-left-color: #f5222d;
    }
}

/* 4. Estilo do Número da Reparação (comum a ambos os modos) */
.reparacao-numero {
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 0.85em;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #1890ff, #007bff);
    padding: 4px 10px;
    border-radius: 12px;
    line-height: 1.2;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.95);
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
}

.reparacao-numero::before { content: "Nª Rep.: "; font-weight: 600; opacity: 0.9; }

/* Mostra o número da reparação apenas quando o cartão tem a classe de status de reparação */
.utilizador-card.status-reparacao .reparacao-numero {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

/* --- Estilos para Opções Avançadas Colapsáveis (configuracoes.php) --- */
.advanced-options {
  margin-top: 1.5rem;
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 0.5rem 1rem;
  background: var(--background-color-hover);
  transition: background .2s, border-color .2s;
}

.advanced-options summary {
  font-weight: 600;
  color: var(--primary-color);
  cursor: pointer;
  padding: 0.5rem 0;
  outline: none; /* Remove o contorno de foco padrão */
  transition: color .2s;
}

.advanced-options[open] > summary {
  margin-bottom: 1rem;
}

.advanced-options .form-2col {
  padding-top: 1rem;
  border-top: 1px dashed var(--border-color);
  transition: border-color .2s;
}

body.dark-mode .advanced-options {
    background: var(--bg-table-even);
    border-color: var(--card-border);
}
}
