/* ========================================================================
   Sistema: Gestão de Confinamento
   Arquivo: styles.css (tema verde sóbrio, moderno e responsivo)
   Objetivos:
     - Visual elegante e atual, mantendo a paleta verde sóbria
     - Correções no tema claro (thead realmente claro, texto consistente)
     - Dark mode com contraste equilibrado
     - Melhor legibilidade em tabelas e formulários
     - Microinterações sutis e acessibilidade reforçada
   ======================================================================== */

/* ============================= Variáveis =============================== */
:root {
  /* Tipografia */
  --font-base: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, Ubuntu, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'SF Mono','JetBrains Mono',Menlo,Consolas,monospace;

  /* Espaçamentos */
  --space-2: .125rem; --space-4: .25rem; --space-6: .375rem; --space-8: .5rem;
  --space-10: .625rem; --space-12: .75rem; --space-16: 1rem; --space-20: 1.25rem;
  --space-24: 1.5rem; --space-32: 2rem;

  /* Paleta Light (verde sóbrio) */
  --bg: #ffffff;
  --bg-alt: #f6f7f6;      /* superfícies secundárias */
  --bg-soft: #f8faf8;     /* superfícies suaves */
  --bg-code: #f1f3f1;
  --border: #d4d9d4;
  --border-strong: #b0b7b0;

  --text: #212625;        /* texto principal */
  --text-soft: #465049;   /* texto secundário */
  --text-mute: #6b726d;   /* texto terciário */

  /* Verde sóbrio */
  --primary: #2f4f3f;
  --primary-hover: #243f32;
  --primary-soft: #e7eee9;

  --danger: #a33a3a;
  --danger-hover: #8b2f2f;
  --danger-soft: #f6eaea;

  --warn: #b3832d;
  --warn-hover: #926923;
  --warn-soft: #fbf3e3;

  --success: #2e6b50;
  --success-hover: #235540;
  --success-soft: #e6f0ea;

  --info: #2f5f6f;
  --info-hover: #254b57;
  --info-soft: #e6eef1;

  /* Radius / Sombras */
  --radius-xs: 4px; --radius-sm: 8px; --radius: 12px; --radius-lg: 16px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06);
  --shadow: 0 6px 18px rgba(0,0,0,.08);
  --shadow-lg: 0 14px 36px rgba(0,0,0,.12);

  /* Foco / Transição */
  --focus-ring-color: color-mix(in oklab, var(--primary) 55%, #ffffff 45%);
  --focus-ring: 0 0 0 3px var(--focus-ring-color);
  --transition: .16s cubic-bezier(.4,0,.2,1);

  /* Z-Index */
  --z-header: 60; --z-sidebar: 100; --z-backdrop: 90; --z-dropdown: 80; --z-modal: 200; --z-toast: 220;

  /* Home (logo) */
  --home-logo-size: 64px;

  color-scheme: light;
}

/* Paleta Dark (verde sóbrio) */
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #121614;
    --bg-alt: #151a17;
    --bg-soft: #161c19;
    --bg-code: #1e2421;
    --border: #262d28;
    --border-strong: #343c36;

    --text: #e6e8e6;
    --text-soft: #c7cdc8;
    --text-mute: #a2aaa5;

    --primary: #3a5f4c;
    --primary-hover: #2e4c3d;
    --primary-soft: #19221e;

    --danger: #d16565;
    --danger-hover: #b75252;
    --danger-soft: #2d1e1e;

    --warn: #d3a760;
    --warn-hover: #b88f4f;
    --warn-soft: #2b2418;

    --success: #3e7f62;
    --success-hover: #31664f;
    --success-soft: #1d2723;

    --info: #4b7c88;
    --info-hover: #3c646d;
    --info-soft: #1a2427;

    --focus-ring-color: color-mix(in oklab, var(--primary) 60%, #000 40%);
    --shadow-sm: 0 1px 2px rgba(0,0,0,.45);
    --shadow: 0 8px 20px rgba(0,0,0,.5);
    --shadow-lg: 0 20px 50px rgba(0,0,0,.6);

    color-scheme: dark;
  }
}

/* Overrides manuais (botão de Tema) */
:root[data-theme="dark"],
.manual-dark {
  --bg: #121614;
  --bg-alt: #151a17;
  --bg-soft: #161c19;
  --bg-code: #1e2421;
  --border: #262d28;
  --border-strong: #343c36;

  --text: #e6e8e6;
  --text-soft: #c7cdc8;
  --text-mute: #a2aaa5;

  --primary: #3a5f4c;
  --primary-hover: #2e4c3d;
  --primary-soft: #19221e;

  --danger: #d16565;
  --danger-hover: #b75252;
  --danger-soft: #2d1e1e;

  --warn: #d3a760;
  --warn-hover: #b88f4f;
  --warn-soft: #2b2418;

  --success: #3e7f62;
  --success-hover: #31664f;
  --success-soft: #1d2723;

  --info: #4b7c88;
  --info-hover: #3c646d;
  --info-soft: #1a2427;

  --focus-ring-color: color-mix(in oklab, var(--primary) 60%, #000 40%);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.45);
  --shadow: 0 8px 20px rgba(0,0,0,.5);
  --shadow-lg: 0 20px 50px rgba(0,0,0,.6);

  color-scheme: dark;
}

:root[data-theme="light"],
.manual-light {
  --bg: #ffffff;
  --bg-alt: #f6f7f6;
  --bg-soft: #f8faf8;
  --bg-code: #f1f3f1;
  --border: #d4d9d4;
  --border-strong: #b0b7b0;

  --text: #212625;
  --text-soft: #465049;
  --text-mute: #6b726d;

  --primary: #2f4f3f;
  --primary-hover: #243f32;
  --primary-soft: #e7eee9;

  --danger: #a33a3a;
  --danger-hover: #8b2f2f;
  --danger-soft: #f6eaea;

  --warn: #b3832d;
  --warn-hover: #926923;
  --warn-soft: #fbf3e3;

  --success: #2e6b50;
  --success-hover: #235540;
  --success-soft: #e6f0ea;

  --info: #2f5f6f;
  --info-hover: #254b57;
  --info-soft: #e6eef1;

  --focus-ring-color: color-mix(in oklab, var(--primary) 55%, #fff 45%);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06);
  --shadow: 0 6px 18px rgba(0,0,0,.08);
  --shadow-lg: 0 14px 36px rgba(0,0,0,.12);

  color-scheme: light;
}

/* Ajuste responsivo (Home) */
@media (max-width: 480px) { :root { --home-logo-size: 56px; } }

/* ============================= Base / Reset ============================= */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-base);
  background: var(--bg); color: var(--text); line-height: 1.55;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  min-height: 100vh; display: flex; flex-direction: column;
}
a {
  color: var(--primary); text-decoration: none;
  transition: color var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
a:hover, a:focus-visible { color: var(--primary-hover); }
img, svg { max-width: 100%; height: auto; vertical-align: middle; }
button, input, select, textarea { font-family: inherit; font-size: 100%; }
:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 8px; }
.user-is-tabbing :focus { box-shadow: var(--focus-ring); outline: none; }

.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

/* ============================= Layout ======================== */
header {
  background: color-mix(in oklab, var(--bg-alt) 92%, transparent);
  border-bottom: 1px solid var(--border);
  padding: var(--space-12) var(--space-20); display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--space-14); position: sticky; top: 0; z-index: var(--z-header);
  backdrop-filter: saturate(1.1) blur(6px);
}
header h1 { font-size: 1.2rem; margin: 0; font-weight: 700; letter-spacing: .3px; }
header h1 a { color: var(--text); }
header h1 a:hover { color: color-mix(in oklab, var(--text) 70%, var(--primary) 30%); }
.flex-break { flex-basis: 100%; height: 0; }

nav.main-nav { display: flex; flex-wrap: wrap; gap: var(--space-8); }
nav.main-nav a {
  padding: .55rem .8rem; font-size: .85rem; font-weight: 600; border-radius: var(--radius-sm);
  background: transparent; border: 1px solid transparent;
  transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
  line-height: 1.1;
}
nav.main-nav a.active {
  background: var(--primary); color: #fff; box-shadow: var(--shadow-sm);
  border-color: color-mix(in oklab, var(--primary) 45%, var(--border) 55%);
}
nav.main-nav a:hover:not(.active) { background: var(--bg-soft); border-color: var(--border); transform: translateY(-1px); }
nav.main-nav a:focus-visible { border-color: var(--primary); background: var(--primary-soft); }

.nav-right { margin-left: auto; display: flex; align-items: center; gap: .6rem; }
.theme-toggle {
  appearance: none; padding: .5rem .7rem; border: 1px solid var(--border);
  background: var(--bg); color: var(--text); border-radius: var(--radius-sm); font-size: .85rem; cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.theme-toggle:hover { background: var(--bg-soft); transform: translateY(-1px); }
.theme-toggle:active { transform: translateY(1px); }

main { max-width: 1200px; margin: var(--space-20) auto 0; padding: 0 var(--space-20); flex: 1 0 auto; }

footer {
  background: color-mix(in oklab, var(--bg-alt) 95%, transparent);
  border-top: 1px solid var(--border); padding: var(--space-20);
  text-align: center; font-size: .8rem; color: var(--text-mute); margin-top: auto;
}

/* ============================= Sidebar Mobile =========================== */
.sidebar {
  position: fixed; top: 0; left: 0; width: 80vw; max-width: 320px; height: 100%;
  background: var(--bg-alt); border-right: 1px solid var(--border);
  z-index: var(--z-sidebar); transform: translateX(-100%); transition: transform .28s ease-out;
  box-shadow: var(--shadow-lg); overflow-y: auto; padding: var(--space-16) 0;
  backdrop-filter: blur(6px);
}
.sidebar.is-open { transform: translateX(0); }
.sidebar-backdrop {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0, 0, 0, 0.45); z-index: var(--z-backdrop);
  opacity: 0; visibility: hidden; transition: opacity .28s ease-out, visibility .28s ease-out;
}
.sidebar-backdrop.is-visible { opacity: 1; visibility: visible; }

.sidebar-header { display: flex; justify-content: space-between; align-items: center; padding: 0 var(--space-16) var(--space-16); border-bottom: 1px solid var(--border); margin-bottom: var(--space-16); }
.sidebar-header .site-title { font-size: 1.12rem; font-weight: 800; margin: 0; letter-spacing: .2px; }
.close-sidebar-btn { background: transparent; border: none; font-size: 1.8rem; line-height: 1; color: var(--text-soft); cursor: pointer; padding: 0; border-radius: 8px; }
.close-sidebar-btn:hover { color: var(--text); transform: scale(1.02); }

.sidebar-nav { display: flex; flex-direction: column; gap: var(--space-4); padding: 0 var(--space-16); }
.sidebar-nav a {
  display: block; padding: var(--space-10) var(--space-12); font-size: .92rem; font-weight: 600;
  border-radius: var(--radius-sm); color: var(--text);
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.sidebar-nav a.active { background: var(--primary); color: #fff; }
.sidebar-nav a:hover:not(.active) { background: var(--bg-soft); transform: translateX(2px); }

.menu-toggle-btn { appearance: none; background: transparent; border: none; font-size: 1.6rem; line-height: 1; color: var(--text); cursor: pointer; padding: 0; margin-right: var(--space-8); }
.menu-toggle-btn:hover { transform: translateY(-1px); }

@media (min-width: 768px) { .menu-toggle-btn, .sidebar, .sidebar-backdrop { display: none !important; } .desktop-nav { display: flex !important; } }
@media (max-width: 767px) { .desktop-nav { display: none !important; } header { padding: var(--space-12) var(--space-16); } }

/* ============================= Tipografia & Helpers ===================== */
h2, h3, h4 { font-weight: 700; line-height: 1.25; color: var(--text); margin-top: 1.8rem; margin-bottom: .8rem; }
h2.mt-0, h3.mt-0, h4.mt-0 { margin-top: 0; }
p { margin: .5rem 0 1rem; color: var(--text); }
small { font-size: .78rem; color: var(--text-mute); }
.mute { color: var(--text-mute); } .soft { color: var(--text-soft); }
.center { text-align: center; } .right { text-align: right; } .nowrap { white-space: nowrap; }
.ml { margin-left: .5rem; } .mr { margin-right: .5rem; }
hr { border: none; border-top: 1px solid var(--border); margin: 2rem 0 1.5rem; }
.code-inline { font-family: var(--font-mono); background: var(--bg-code); padding: 2px 6px; border-radius: var(--radius-xs); font-size: .76rem; color: var(--text); }

/* ============================= Botões ================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  padding: .55rem 1rem; font-size: .86rem; font-weight: 700; line-height: 1.2;
  border-radius: var(--radius-sm); cursor: pointer; text-decoration: none; transition: all var(--transition);
  user-select: none; border: 1px solid transparent; will-change: transform, box-shadow;
}
.btn-primary { background: var(--primary); color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover { background: var(--primary-hover); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-primary:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn-primary:focus-visible { box-shadow: var(--focus-ring), var(--shadow-sm); }
.btn-secondary { background: var(--bg-alt); color: var(--text); border-color: var(--border); }
.btn-secondary:hover { background: var(--bg-soft); border-color: var(--border-strong); transform: translateY(-1px); }
.btn-danger { background: var(--danger); color: #fff; }
.btn-danger:hover { background: var(--danger-hover); transform: translateY(-1px); }
.btn.outline { background: transparent; border-width: 1px; }
.btn-primary.outline { color: var(--primary); border-color: var(--primary); }
.btn-primary.outline:hover { background: var(--primary-soft); }
.btn.small { padding: .38rem .75rem; font-size: .78rem; border-radius: 7px; }
.btn:disabled, .btn.disabled { opacity: .6; cursor: not-allowed; box-shadow: none; transform: none; }

/* ============================= Tabelas ================================= */
/* Correção: cabeçalho CLARO no modo claro com alta especificidade */
.table-responsive {
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border); border-radius: var(--radius); background: var(--bg);
  margin-bottom: 1.25rem; box-shadow: var(--shadow-sm);
}

table {
  border-collapse: collapse; width: 100%; margin: 0;
  font-size: .86rem; background: var(--bg); position: relative; color: var(--text);
}

/* Força fundo claro no thead no tema claro (evita overrides externos) */
:root[data-theme="light"] table thead th,
.manual-light table thead th {
  background: #fbfcfb !important;   /* ainda mais claro que var(--bg-soft) */
  color: var(--text) !important;
  border-color: var(--border) !important;
}

table thead th {
  font-weight: 700; padding: .7rem .65rem;
  border: 1px solid var(--border);
  text-align: left; position: sticky; top: 0; z-index: 5;
}

tbody td {
  border: 1px solid var(--border); padding: .6rem .6rem;
  color: var(--text); background: var(--bg);
}
tbody tr:nth-child(even) { background: var(--bg-soft); }

/* Em hover, aplicar fundo suave só nas células, mantendo legibilidade */
tbody tr:hover td {
  background: var(--primary-soft);
  transition: background var(--transition);
}

/* Ações em tabela */
.table-actions { display: flex; gap: .45rem; align-items: center; justify-content: center; white-space: nowrap; }
.table-actions .btn { padding: .22rem .45rem; font-size: .72rem; border-radius: 7px; }

/* DARK MODE: cabeçalho e zebra ajustados para o tema escuro */
@media (prefers-color-scheme: dark) {
  table { color: var(--text); background: var(--bg); }
  table thead th { background: #121614 !important; color: var(--text-soft) !important; }
  tbody td { background: var(--bg); color: var(--text); }
  tbody tr:nth-child(even) { background: #141816; }
}

/* ============================= Formulários ============================= */
form { max-width: 900px; }
form .field-group { display: flex; flex-wrap: wrap; gap: .85rem; margin-bottom: 1rem; }
label {
  font-size: .72rem; font-weight: 700; letter-spacing: .3px; text-transform: uppercase;
  display: block; color: var(--text-soft); margin-bottom: 6px;
}
input[type=text], input[type=number], input[type=password], input[type=date],
input[type=email], select, textarea {
  width: 100%; background: var(--bg-soft); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: .6rem .7rem; font-size: .86rem;
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition), transform var(--transition), color var(--transition);
}
input:hover, select:hover, textarea:hover { border-color: var(--border-strong); }
input:focus-visible, select:focus-visible, textarea:focus-visible {
  border-color: var(--primary); background: var(--bg);
  box-shadow: var(--focus-ring);
  transform: translateY(-1px);
  color: var(--text);
}
input::placeholder, textarea::placeholder { color: color-mix(in oklab, var(--text) 50%, #999 50%); opacity: .7; }
select { color: var(--text); }
input[disabled], select[disabled], textarea[disabled] { opacity: .6; cursor: not-allowed; }
textarea { min-height: 140px; resize: vertical; }
fieldset { border: 1px solid var(--border); padding: .95rem 1.1rem 1.1rem; border-radius: var(--radius); margin: 1rem 0 1.25rem; background: color-mix(in oklab, var(--bg-alt) 85%, transparent); }
legend { font-weight: 700; font-size: .78rem; padding: 0 .5rem; color: var(--text-soft); text-transform: uppercase; letter-spacing: .32px; }
.errorlist { list-style: none; margin: .35rem 0 .6rem; padding: 0; font-size: .74rem; color: var(--danger); }

/* ============================= Alerts / Messages ======================== */
.messages {
  margin: 0 0 1.25rem; display: grid; gap: .7rem;
  backdrop-filter: blur(6px);
}
.message {
  padding: .75rem .9rem; font-size: .78rem; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: var(--bg-alt); box-shadow: var(--shadow-sm);
  position: relative; display: flex; align-items: center; justify-content: space-between;
  transition: transform var(--transition), opacity var(--transition), box-shadow var(--transition), background var(--transition);
  color: var(--text);
}
.message:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.message.success { border-color: var(--success); background: var(--success-soft); color: var(--success); }
.message.error   { border-color: var(--danger);  background: var(--danger-soft);  color: var(--danger); }
.message.warning { border-color: var(--warn);    background: var(--warn-soft);    color: var(--warn); }
.message.info    { border-color: var(--info);    background: var(--info-soft);    color: var(--info); }
.message .close-msg {
  flex-shrink: 0; margin-left: 1rem; background: transparent; border: none; font-size: .9rem; cursor: pointer;
  color: inherit; line-height: 1; padding: .2rem .35rem; border-radius: var(--radius-xs); transition: background var(--transition), transform var(--transition);
}
.message .close-msg:hover { background: rgba(0,0,0,.05); transform: translateY(-1px); }
@media (prefers-color-scheme: dark) {
  .message { color: var(--text); }
  .message.success { color:#a2d1b6; }
  .message.error   { color:#efb0b0; }
  .message.warning { color:#e9d1a3; }
  .message.info    { color:#a9c7cf; }
  .message .close-msg:hover { background: rgba(255,255,255,.08); }
}

/* ============================= Badges / Status ========================= */
.status {
  font-weight: 800; padding: 3px 8px; border-radius: 999px;
  font-size: .68rem; letter-spacing: .6px; display: inline-block; text-transform: uppercase; line-height: 1.1;
}
.status-completo { background: var(--success); color: #fff; }
.status-parcial  { background: var(--warn);    color: #fff; }
.status-nao      { background: var(--danger);  color: #fff; }
.status-info     { background: var(--info);    color: #fff; }
.status-soft { background: var(--bg-soft); color: var(--text-soft); border: 1px solid var(--border); font-weight: 700; }

/* ============================= Progress Bar ============================ */
.progress-bar { background: var(--bg-soft); border-radius: var(--radius-sm); height: 12px; position: relative; overflow: hidden; border: 1px solid var(--border); }
.progress-fill { background: linear-gradient(90deg, var(--primary), var(--primary-hover)); height: 100%; width: 0; max-width: 100%; transition: width .38s ease; }

/* ============================= Cards / Painéis ========================= */
.card {
  background: color-mix(in oklab, var(--bg-alt) 94%, transparent);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1rem 1.1rem; box-shadow: var(--shadow-sm); position: relative;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition), background var(--transition);
  color: var(--text);
}
.card:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.card:not(:last-child) { margin-bottom: .85rem; }
.card-title { font-size: .8rem; font-weight: 800; margin: 0 0 .5rem; color: var(--text-soft); letter-spacing: .4px; text-transform: uppercase; }
.card-value { font-size: 1.22rem; font-weight: 700; color: var(--text); letter-spacing: .5px; line-height: 1.2; }
.cards-grid { display: grid; gap: .85rem; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); margin: .85rem 0 1.3rem; }

/* ============================= Pagination ============================= */
.pagination { margin-top: .85rem; display: flex; gap: .6rem; flex-wrap: wrap; }
.pagination a, .pagination span {
  padding: .45rem .7rem; font-size: .74rem; border-radius: 999px; border: 1px solid var(--border);
  background: var(--bg-soft); color: var(--text-soft); text-decoration: none;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.pagination a:hover { background: var(--primary); color: #fff; border-color: var(--primary); transform: translateY(-1px); }
.pagination span[aria-current="page"] { background: var(--primary-soft); border-color: var(--primary); color: var(--primary); font-weight: 800; }

/* ============================= Utilitários ============================= */
.inline { display: inline-block; } .block { display: block; } .flex { display: flex; }
.flex-col { display:flex; flex-direction:column; } .flex-wrap { flex-wrap:wrap; } .flex-center { display:flex; align-items:center; justify-content:center; }
.justify-between { justify-content: space-between; }
.gap-xs { gap: .35rem; } .gap-sm { gap: .55rem; } .gap { gap: .75rem; } .gap-lg { gap: 1rem; }
.mt-0 { margin-top: 0 !important; } .mt-xs { margin-top: .25rem !important; } .mt-sm { margin-top: .5rem !important; }
.mt { margin-top: 1rem !important; } .mt-lg { margin-top: 2rem !important; }
.mb-0 { margin-bottom: 0 !important; } .mb-xs { margin-bottom: .25rem !important; } .mb-sm { margin-bottom: .5rem !important; }
.mb { margin-bottom: 1rem !important; } .mb-lg { margin-bottom: 2rem !important; }
.p-xs { padding: .25rem !important; } .p-sm { padding: .5rem !important; } .p { padding: .75rem !important; } .p-lg { padding: 1.25rem !important; }
.text-right { text-align: right !important; } .text-center { text-align: center !important; }
.hide { display: none !important; }
.max-w-sm { max-width: 420px; } .max-w-md { max-width: 640px; } .max-w-lg { max-width: 900px; } .w-100 { width: 100%; }
.clamp-line { display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow:hidden; }
[data-busy="true"] { opacity:.6; pointer-events:none; }
@media (max-width: 780px) { .hide-mobile { display: none !important; } }

/* ============================= Print ============================ */
@media print {
  header, footer, .btn, nav.main-nav, .pagination, .messages, .theme-toggle, .menu-toggle-btn, .sidebar, .sidebar-backdrop { display: none !important; }
  body { background: #fff; color: #000; font-size: 11pt; }
  table, th, td { border: 1px solid #000 !important; }
  a { color: #000; text-decoration: underline; }
  .card { box-shadow: none !important; border-color: #000 !important; }
}

/* ============================= Motion ====================== */
.fade-in { animation: fadeIn .34s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.loader { width: 42px; height: 42px; border: 4px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: spin 1s linear infinite; margin: 1rem auto; }
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .fade-in { animation: none; }
  .loader  { animation: none; border-top-color: var(--primary); }
}

/* ============================= Acessibilidade ==================== */
.skip-link { position: absolute; left: -999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus {
  position: static; width: auto; height: auto; background: var(--primary); color: #fff;
  padding: .55rem .8rem; border-radius: var(--radius-sm); z-index: var(--z-header);
  box-shadow: var(--shadow);
}

/* ============================= Home ====================== */
.home-logo { width: var(--home-logo-size); height: var(--home-logo-size); border-radius: 16px; object-fit: cover; box-shadow: var(--shadow-sm); animation: logoFloat 3s ease-in-out infinite; }
@keyframes logoFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@media (prefers-reduced-motion: reduce) { .home-logo { animation: none !important; } }

.home-chips { display:flex; gap:.6rem; flex-wrap:wrap; justify-content:center; }
.chip {
  display:inline-flex; align-items:center; gap:.4rem; padding:.35rem .6rem;
  border-radius:999px; border:1px solid var(--border); background:var(--bg-soft); color:var(--text-soft);
  font-size:.78rem; line-height:1; box-shadow: var(--shadow-sm); transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}
.chip:hover { transform: translateY(-1px); box-shadow: var(--shadow); background: color-mix(in oklab, var(--bg-soft) 80%, var(--primary-soft) 20%); }
.chip-info { border-color: var(--info); color: var(--info); background: var(--info-soft); }
.chip-soft { border-color: var(--border); color: var(--text-soft); background: var(--bg-soft); }

.home-loader { display: none !important; }