/* ===================================================================
   Guia Rápido de Inclusão · CENLEP · UNICSUL · 2026
   Estilo institucional · paleta nova (ciano logo + cream + navy + amber)
   =================================================================== */

/* ---------- 1. TOKENS ---------- */
:root {
  /* Cores */
  --c-bg: #FBF7F1;
  --c-bg-soft: #FFFFFF;
  --c-bg-card: #FFFFFF;
  --c-bg-muted: #F1F5F9;
  --c-text: #0B203C;
  --c-text-muted: #475569;
  --c-text-subtle: #64748B;

  --c-primary: #4FC3F7;        /* ciano do logo */
  --c-primary-strong: #0288D1; /* p/ texto/link sobre branco */
  --c-primary-dark: #01579B;
  --c-primary-soft: #E1F5FE;

  --c-accent: #F59E0B;         /* amber */
  --c-accent-soft: #FEF3C7;

  --c-success: #059669;
  --c-success-soft: #D1FAE5;
  --c-danger: #DC2626;
  --c-danger-soft: #FEE2E2;
  --c-warning: #D97706;
  --c-warning-soft: #FEF3C7;

  --c-border: #E2E8F0;
  --c-border-strong: #CBD5E1;

  /* Tipografia */
  --font-display: 'Lora', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --fs-xs: 0.8125rem;   /* 13 */
  --fs-sm: 0.9375rem;   /* 15 */
  --fs-base: 1.0625rem; /* 17 */
  --fs-md: 1.1875rem;   /* 19 */
  --fs-lg: 1.5rem;      /* 24 */
  --fs-xl: 2rem;        /* 32 */
  --fs-2xl: 2.75rem;    /* 44 */
  --fs-3xl: 3.5rem;     /* 56 */

  --lh-tight: 1.2;
  --lh-snug: 1.4;
  --lh-base: 1.65;
  --lh-relaxed: 1.75;

  --measure: 68ch;

  /* Espaçamento */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;

  /* Forma */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-pill: 999px;

  /* Sombra */
  --shadow-xs: 0 1px 2px rgba(11, 32, 60, 0.05);
  --shadow-sm: 0 2px 6px rgba(11, 32, 60, 0.06);
  --shadow-md: 0 6px 20px rgba(11, 32, 60, 0.08);
  --shadow-lg: 0 16px 40px rgba(11, 32, 60, 0.12);

  /* Animação */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --t-fast: 150ms;
  --t-med: 250ms;
}

/* ---------- 2. RESET LEVE ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--c-text);
  background: var(--c-bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; height: auto; }
a { color: var(--c-primary-strong); text-decoration-thickness: 1.5px; text-underline-offset: 3px; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--c-primary-dark); }
button { font-family: inherit; font-size: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul, ol { list-style: none; }

/* Focus visível */
:focus-visible {
  outline: 3px solid var(--c-primary);
  outline-offset: 3px;
  border-radius: 4px;
}
button:focus-visible, a:focus-visible { outline-offset: 4px; }

/* Skip link */
.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 999;
  background: var(--c-text);
  color: white;
  padding: 12px 20px;
  border-radius: var(--radius-md);
  font-weight: 600;
}
.skip-link:focus { left: 16px; top: 16px; }

/* ---------- 3. LAYOUT ---------- */
.container {
  width: 100%;
  max-width: 1120px;
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 32px);
}
.container-narrow { max-width: 760px; margin-inline: auto; padding-inline: clamp(16px, 4vw, 32px); }

/* ---------- 4. TOPBAR ---------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(251, 247, 241, 0.92);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid rgba(11, 32, 60, 0.06);
}
.topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-block: 14px;
  min-height: 64px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--c-text);
}
.brand img { width: 36px; height: 36px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.brand-text strong { font-family: var(--font-display); font-size: 1.0625rem; font-weight: 600; }
.brand-text small { font-size: 0.75rem; color: var(--c-text-muted); }
.topbar-actions { display: flex; align-items: center; gap: 8px; }
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  min-height: 44px;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.btn-ghost:hover { background: var(--c-bg-muted); color: var(--c-text); }
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  min-height: 44px;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: white;
  background: var(--c-primary-strong);
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.btn-primary:hover { background: var(--c-primary-dark); color: white; }
.btn-primary:active { transform: translateY(1px); }

/* ---------- 5. HERO ---------- */
.hero {
  padding-block: clamp(48px, 8vw, 96px);
  background:
    radial-gradient(circle at 80% 10%, rgba(79, 195, 247, 0.12), transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(245, 158, 11, 0.08), transparent 50%);
}
.hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(32px, 5vw, 56px);
  align-items: center;
}
@media (min-width: 880px) {
  .hero-inner { grid-template-columns: 1fr 1.15fr; }
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: var(--c-primary-soft);
  color: var(--c-primary-dark);
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw, var(--fs-3xl));
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--c-text);
  margin-bottom: 16px;
}
.hero-title em { font-style: italic; color: var(--c-primary-strong); }
.hero-sub {
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
  color: var(--c-text-muted);
  max-width: 60ch;
  margin-bottom: 28px;
}
.hero-meta { color: var(--c-text-subtle); font-size: var(--fs-sm); margin-bottom: 32px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }
.hero-visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.hero-visual .ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(79, 195, 247, 0.18), transparent 60%);
  z-index: 0;
}
.hero-visual picture {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  max-width: 560px;
  margin-inline: auto;
}
.hero-visual img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  margin-inline: auto;
  filter: drop-shadow(0 16px 32px rgba(11, 32, 60, 0.10));
}

/* ---------- 6. TABS ---------- */
.tabs-wrap {
  position: sticky;
  top: 64px;
  z-index: 40;
  background: rgba(251, 247, 241, 0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-block: 1px solid var(--c-border);
}
.tabs {
  display: flex;
  gap: 4px;
  overflow-x: auto;
  scrollbar-width: thin;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-block: 8px;
}
.tabs::-webkit-scrollbar { height: 4px; }
.tabs::-webkit-scrollbar-thumb { background: var(--c-border-strong); border-radius: 4px; }

.tab {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  min-height: 44px;
  white-space: nowrap;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  scroll-snap-align: start;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  border: 1px solid transparent;
}
.tab:hover { background: var(--c-bg-muted); color: var(--c-text); }
.tab[aria-selected="true"] {
  background: var(--c-text);
  color: white;
  font-weight: 600;
}
.tab .num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.18);
}
.tab[aria-selected="false"] .num { background: var(--c-primary-soft); color: var(--c-primary-dark); }

/* ---------- 7. PANELS ---------- */
main { padding-block: clamp(48px, 6vw, 80px); }
/* Default visível (importante pra @media print revelar todos). */
.panel { display: block; }
/* Em telas, só o ativo é visível. Print ignora @media screen. */
@media screen {
  .panel { display: none; animation: fadeIn 350ms var(--ease); }
  .panel.is-active { display: block; }
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .panel, * { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}

/* Headings */
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--c-text); line-height: var(--lh-tight); letter-spacing: -0.01em; font-weight: 600; }
h2 { font-size: clamp(1.75rem, 4vw, var(--fs-2xl)); margin-bottom: 16px; }
h3 { font-size: clamp(1.25rem, 2.5vw, var(--fs-xl)); margin-block: 32px 12px; font-weight: 600; }
h4 { font-size: var(--fs-md); margin-block: 16px 8px; font-weight: 600; }
p { margin-bottom: 16px; max-width: var(--measure); }
.panel p { color: var(--c-text); }
strong { color: var(--c-text); font-weight: 600; }

/* Eyebrow das seções */
.section-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-primary-strong);
  margin-bottom: 8px;
  max-width: none;
}

/* Considerações finais (encerra a Aba 6) */
.consideracoes-finais {
  text-align: center;
  padding-block: clamp(40px, 6vw, 72px);
  margin-top: clamp(32px, 5vw, 48px);
  border-top: 1px solid var(--c-border);
}
.consideracoes-finais .section-eyebrow { margin-bottom: 12px; }
.consideracoes-finais h2 {
  max-width: 24ch;
  margin-inline: auto;
  margin-bottom: 20px;
}
.consideracoes-finais p {
  max-width: 56ch;
  margin-inline: auto;
  margin-bottom: 12px;
}
.consideracoes-finais p:last-child { margin-bottom: 0; }

/* ---------- 8. CARDS / CALLOUTS ---------- */
.card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(20px, 3vw, 32px);
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.card:hover { box-shadow: var(--shadow-md); }

.callout {
  display: flex;
  gap: 16px;
  padding: 20px 24px;
  border-radius: var(--radius-md);
  background: var(--c-bg-card);
  border-left: 4px solid var(--c-primary);
  margin-block: 24px;
  max-width: var(--measure);
}
.callout-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  color: var(--c-primary-strong);
}
.callout h4 { margin-top: 0; }
.callout p:last-child { margin-bottom: 0; }
.callout--warning { background: var(--c-warning-soft); border-left-color: var(--c-warning); }
.callout--warning .callout-icon { color: var(--c-warning); }
.callout--danger { background: var(--c-danger-soft); border-left-color: var(--c-danger); }
.callout--danger .callout-icon { color: var(--c-danger); }
.callout--success { background: var(--c-success-soft); border-left-color: var(--c-success); }
.callout--success .callout-icon { color: var(--c-success); }

/* Citação */
.quote {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.625rem);
  font-style: italic;
  line-height: 1.4;
  color: var(--c-text);
  padding: 24px 32px;
  border-left: 4px solid var(--c-accent);
  background: var(--c-bg-soft);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin-block: 32px;
  max-width: var(--measure);
  position: relative;
}
.quote::before {
  content: '“';
  position: absolute;
  top: -8px;
  left: 16px;
  font-size: 4rem;
  color: var(--c-accent);
  line-height: 1;
  font-family: var(--font-display);
}
.quote cite { display: block; margin-top: 12px; font-size: var(--fs-sm); color: var(--c-text-muted); font-style: normal; font-family: var(--font-body); }
.quote cite::before { content: ''; }

/* ---------- 9. GRIDS ---------- */
.grid {
  display: grid;
  gap: clamp(16px, 2.5vw, 24px);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  margin-block: 32px;
}
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

/* ---------- 10. NÍVEIS DE INCLUSÃO (Aba 2) ---------- */
.niveis {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-block: 32px;
}
.nivel {
  display: flex;
  flex-direction: column;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 24px;
  text-align: left;
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.nivel:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.nivel-svg, .nivel-img {
  width: 100%;
  aspect-ratio: 1;
  max-width: 240px;
  margin-inline: auto;
  margin-bottom: 16px;
  object-fit: contain;
}
.nivel picture { display: block; width: 100%; }
.nivel-num {
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--c-text-muted);
  text-transform: uppercase;
}
.nivel-title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--c-text);
  margin-block: 4px 8px;
}
.nivel-desc { font-size: var(--fs-sm); color: var(--c-text-muted); margin: 0; }
.nivel--inclusao { border-color: var(--c-primary); background: linear-gradient(180deg, var(--c-primary-soft) 0%, white 50%); }
.nivel--inclusao .nivel-title { color: var(--c-primary-dark); }

/* Tipos de acessibilidade */
.acess-list {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
  margin-block: 24px;
}
@media (min-width: 560px) {
  .acess-list { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 880px) {
  .acess-list { grid-template-columns: repeat(3, 1fr); }
}
.acess-item {
  display: flex;
  gap: 16px;
  padding: 20px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}
.acess-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--c-primary-soft);
  color: var(--c-primary-dark);
  display: flex;
  align-items: center;
  justify-content: center;
}
.acess-icon svg { width: 28px; height: 28px; }
.acess-item h4 { margin: 0 0 4px; font-family: var(--font-body); font-size: 1rem; font-weight: 600; }
.acess-item p { margin: 0; font-size: var(--fs-sm); color: var(--c-text-muted); }
.acess-item:nth-child(6) .acess-icon { background: var(--c-accent-soft); color: var(--c-warning); }

/* ---------- 11. LEIS / CARDS DE LEGISLAÇÃO (Aba 3) ---------- */
.lei {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: 24px;
  background: var(--c-bg-card);
  margin-block: 16px;
}
.lei-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.lei-badge {
  display: inline-flex;
  padding: 4px 10px;
  background: var(--c-primary-soft);
  color: var(--c-primary-dark);
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
}
.lei h3 { margin: 0; font-size: var(--fs-md); font-weight: 600; }
.lei-points { margin-block: 12px 16px; padding-left: 0; }
.lei-points li { position: relative; padding-left: 22px; margin-bottom: 6px; color: var(--c-text-muted); font-size: var(--fs-sm); }
.lei-points li::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 9px;
  width: 6px;
  height: 6px;
  background: var(--c-primary);
  border-radius: 50%;
}
.lei-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  font-weight: 500;
  word-break: break-word;
}
.lei-link::after { content: '→'; transition: transform var(--t-fast) var(--ease); }
.lei-link:hover::after { transform: translateX(3px); }

/* ---------- 12. NEURODIVERGÊNCIA (Aba 4) ---------- */
.cond-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 28px;
  margin-block: 16px;
}
.cond-head { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.cond-tag {
  display: inline-flex;
  padding: 4px 12px;
  background: var(--c-primary-soft);
  color: var(--c-primary-dark);
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
}
.cond-card h3 { margin: 0; font-size: var(--fs-lg); }
.cond-card .desc { color: var(--c-text); margin-bottom: 16px; }
.cond-card .practice {
  background: var(--c-primary-soft);
  border-radius: var(--radius-md);
  padding: 16px 20px;
  margin-top: 12px;
}
.cond-card .practice strong { color: var(--c-primary-dark); display: block; margin-bottom: 4px; font-size: var(--fs-sm); letter-spacing: 0.04em; text-transform: uppercase; }
.cond-card .practice p { margin: 0; font-size: var(--fs-sm); color: var(--c-text); }

.sinais {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  margin-block: 16px;
}
.sinal {
  padding: 14px 18px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-left: 3px solid var(--c-accent);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--c-text);
}

/* ---------- 13. BULLYING (Aba 5) ---------- */
.acoes { display: grid; gap: 16px; margin-block: 24px; }
.acao {
  display: flex;
  gap: 20px;
  padding: 20px 24px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}
.acao-num {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--c-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.125rem;
}
.acao h4 { margin: 0 0 4px; font-family: var(--font-body); font-size: 1rem; font-weight: 600; }
.acao p { margin: 0; font-size: var(--fs-sm); color: var(--c-text-muted); }

/* ---------- 14. TABELA DE ENCAMINHAMENTO (Aba 6) ---------- */
.encaminha-wrap { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--c-border); background: var(--c-bg-card); margin-block: 24px; }
.encaminha {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.encaminha thead { background: var(--c-text); color: white; }
.encaminha th, .encaminha td { padding: 14px 18px; text-align: left; vertical-align: top; }
.encaminha th { font-weight: 600; letter-spacing: 0.02em; font-size: var(--fs-xs); text-transform: uppercase; }
.encaminha tbody tr { border-top: 1px solid var(--c-border); }
.encaminha tbody tr:nth-child(even) { background: var(--c-bg-muted); }
.encaminha td:first-child { font-weight: 600; color: var(--c-text); }
.encaminha td.contato { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-weight: 600; color: var(--c-primary-dark); }
.encaminha td.danger { color: var(--c-danger); font-weight: 700; }

/* Instituições */
.inst-card {
  padding: 20px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.inst-card h4 { margin: 0; font-family: var(--font-display); font-size: 1.125rem; }
.inst-card .sigla { font-family: var(--font-body); font-weight: 700; color: var(--c-primary-strong); font-size: var(--fs-sm); letter-spacing: 0.04em; }
.inst-card .desc { font-size: var(--fs-sm); color: var(--c-text-muted); margin: 0; }
.inst-card a { margin-top: 4px; font-size: var(--fs-sm); font-weight: 500; word-break: break-all; }

/* Filmes */
.filmes { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-block: 16px; }
.filme {
  padding: 18px 20px;
  border: 1px solid var(--c-border);
  border-left: 3px solid var(--c-primary);
  border-radius: var(--radius-md);
  background: var(--c-bg-card);
}
.filme .tipo { font-size: var(--fs-xs); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-primary-strong); }
.filme h4 { margin: 4px 0; font-family: var(--font-display); font-size: 1.125rem; }
.filme p { margin: 0; font-size: var(--fs-sm); color: var(--c-text-muted); }

/* Bibliografia */
.biblio {
  display: grid;
  gap: 12px;
  margin-block: 16px;
  list-style: none;
}
.biblio li {
  padding: 14px 18px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--c-text);
}

/* ---------- 15. FOOTER ---------- */
footer {
  background: var(--c-text);
  color: rgba(255, 255, 255, 0.85);
  padding-block: clamp(48px, 6vw, 80px);
  margin-top: clamp(64px, 8vw, 96px);
}
footer h3 { color: white; margin-bottom: 16px; font-size: var(--fs-md); }
footer p { color: rgba(255, 255, 255, 0.75); font-size: var(--fs-sm); }
footer a { color: var(--c-primary); }
footer a:hover { color: white; }
.footer-grid { display: grid; gap: 32px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin-bottom: 40px; }
.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.55);
}
.footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.footer-logo img { width: 32px; filter: brightness(0) invert(1); opacity: 0.9; }
.footer-logo span { font-family: var(--font-display); color: white; font-size: 1.125rem; }
.emerg { display: grid; gap: 8px; margin: 0; }
.emerg li { display: flex; align-items: baseline; gap: 12px; }
.emerg-n {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--c-primary);
  min-width: 36px;
}
.emerg-l { font-size: var(--fs-sm); color: rgba(255, 255, 255, 0.75); }
.creditos {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  padding: clamp(20px, 3vw, 32px);
  font-size: var(--fs-sm);
}
.creditos strong { color: white; }
.creditos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(20px, 3vw, 40px);
}
.creditos-h {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: white;
  margin: 0 0 12px;
}
.creditos p { margin-bottom: 4px; color: rgba(255, 255, 255, 0.85); }
.creditos .crp { color: rgba(255, 255, 255, 0.55); font-size: var(--fs-xs); }

/* ---------- 16. UTILS ---------- */
.center { text-align: center; }
.lede { font-size: var(--fs-md); color: var(--c-text-muted); max-width: var(--measure); }
.divider { height: 1px; background: var(--c-border); margin-block: clamp(40px, 6vw, 64px); border: 0; }
.muted { color: var(--c-text-muted); }
.tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--c-bg-muted);
  color: var(--c-text-muted);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* ---------- 17. PRINT (PDF) ---------- */
@page {
  size: A4;
  margin: 16mm 14mm 16mm 14mm;
}

@media print {
  :root {
    --c-bg: white;
    --c-bg-card: white;
    --c-bg-muted: #f7f7f7;
    --c-text: #0B203C;
    --c-text-muted: #444;
    --c-text-subtle: #555;
  }

  /* Reset cores e fontes para print */
  *, *::before, *::after {
    background: transparent !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  html, body {
    background: white;
    color: var(--c-text);
    font-size: 10.5pt;
    line-height: 1.45;
  }

  /* Esconde tudo que não serve no PDF */
  .skip-link,
  .topbar,
  .tabs-wrap,
  .hero-cta,
  .hero-visual,
  .hero-eyebrow,
  .btn-primary,
  .btn-ghost,
  .callout--success,
  .footer-bottom { display: none !important; }

  /* HERO compacto: vira capa simples */
  .hero {
    padding-block: 0 8mm;
    background: none;
  }
  .hero-inner { display: block; }
  .hero-title {
    font-size: 28pt;
    line-height: 1.05;
    margin-bottom: 6pt;
  }
  .hero-title em { color: #0288D1; }
  .hero-sub {
    font-size: 12pt;
    max-width: 100%;
    color: var(--c-text-muted);
    margin-bottom: 4pt;
  }
  .hero-meta { font-size: 9.5pt; color: #666; margin-bottom: 0; }

  /* Container: usa toda a largura do papel */
  .container,
  .container-narrow { max-width: 100% !important; padding: 0 !important; }

  /* PANELS: revela TODAS sem forçar quebra (fluxo natural). Especificidade alta. */
  main .panel,
  .panel,
  .panel:not(.is-active),
  article[role="tabpanel"] { display: block !important; visibility: visible !important; }
  /* Reinicia visual de cada panel pro fluxo natural */
  .panel + .panel { page-break-before: auto; break-before: auto; }
  /* Eyebrow "ABA N" vira um marco visual */
  .section-eyebrow {
    font-size: 9pt;
    color: #0288D1;
    margin-top: 6mm;
    margin-bottom: 2pt;
    letter-spacing: 0.08em;
  }

  /* HEADINGS */
  h1, h2, h3, h4 { color: var(--c-text); page-break-after: avoid; break-after: avoid; }
  h2 {
    font-size: 20pt;
    line-height: 1.1;
    margin: 4mm 0 3mm;
    border-bottom: 1.5pt solid #E2E8F0;
    padding-bottom: 2mm;
  }
  h3 { font-size: 13pt; margin: 5mm 0 2mm; }
  h4 { font-size: 11pt; margin: 3mm 0 1mm; }
  p, li {
    orphans: 3;
    widows: 3;
    page-break-inside: avoid;
    break-inside: avoid;
  }
  p { margin-bottom: 3mm; max-width: 100%; }
  .lede { font-size: 11pt; }

  /* LINKS: só sublinhado, sem injetar URL grandona */
  a { color: #0288D1; text-decoration: underline; }
  a[href^="http"]::after { content: none !important; }
  /* Mas pra links de legislação importantes, mostra URL pequena em itálico */
  .lei-link::after { content: ' (' attr(href) ')' !important; font-size: 8pt; color: #888; font-weight: 400; }
  .lei-link::before { content: '' !important; }
  .lei-link { word-break: break-word; }

  /* CARDS / BLOCOS: evita quebrar no meio */
  .card,
  .lei,
  .cond-card,
  .acao,
  .inst-card,
  .filme,
  .nivel,
  .callout,
  .quote,
  .acess-item,
  .sinal,
  .biblio li { page-break-inside: avoid; break-inside: avoid; }

  /* CARDS visual sem sombra */
  .card,
  .lei,
  .cond-card,
  .inst-card,
  .nivel,
  .acao,
  .filme,
  .acess-item {
    border: 0.5pt solid #d4d4d4;
    border-radius: 4pt;
    padding: 3mm 4mm;
    margin-block: 2mm;
  }

  /* NÍVEIS de inclusão */
  .niveis {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3mm;
  }
  .nivel picture { display: block; width: 100%; margin: 0 auto 2mm; }
  .nivel-img, .nivel-svg {
    display: block !important;
    width: 50mm !important;
    height: auto !important;
    max-height: 50mm;
    margin: 0 auto 2mm !important;
    visibility: visible !important;
    opacity: 1 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .nivel--inclusao { background: #f3f9fd !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .nivel-title { font-size: 12pt; margin: 2mm 0 1mm; }
  .nivel-desc { font-size: 9.5pt; }
  .nivel-num { font-size: 8pt; }

  /* Tipos de acessibilidade: 2 colunas no PDF */
  .acess-list {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 2.5mm !important;
  }
  .acess-item { padding: 2.5mm 3mm; }
  .acess-icon { width: 9mm; height: 9mm; min-width: 9mm; }
  .acess-icon svg { width: 5mm; height: 5mm; }

  /* Citação */
  .quote {
    font-size: 11.5pt;
    padding: 3mm 5mm;
    margin: 4mm 0;
    background: #fafafa !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    border-left: 2pt solid #F59E0B;
  }
  .quote::before { font-size: 18pt; top: 0; }
  .quote cite { font-size: 9pt; }

  /* LEIS: header e bullets compactos */
  .lei-head { gap: 2mm; }
  .lei-badge {
    background: #e1f5fe !important;
    color: #01579B !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    padding: 1pt 6pt;
    font-size: 8pt;
  }
  .lei h3 { font-size: 11.5pt; margin: 0; }
  .lei-points li { font-size: 9.5pt; padding-left: 4mm; margin-bottom: 1pt; }
  .lei-points li::before { left: 0; top: 1.4mm; }

  /* Cards de condição */
  .cond-card .practice {
    background: #f0f8fc !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    padding: 2mm 3mm;
    margin-top: 2mm;
  }
  .cond-tag {
    background: #e1f5fe !important;
    color: #01579B !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* SINAIS: 3 colunas compacto */
  .sinais {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2mm !important;
    margin-block: 3mm !important;
  }
  .sinal {
    padding: 2mm 3mm;
    font-size: 9pt;
    background: #fafafa !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    border-left: 1.5pt solid #F59E0B !important;
  }

  /* AÇÕES contra bullying: compacto */
  .acao {
    display: grid;
    grid-template-columns: 8mm 1fr;
    gap: 2mm;
    padding: 2.5mm 3mm;
  }
  .acao-num {
    width: 7mm;
    height: 7mm;
    font-size: 9pt;
    background: #0288D1 !important;
    color: white !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .acao h4 { font-size: 10pt; }
  .acao p { font-size: 9pt; }

  /* TABELA de encaminhamento: volta a ser tabela no print */
  .encaminha-wrap {
    overflow: visible !important;
    border: 0.5pt solid #d4d4d4;
    border-radius: 3pt;
  }
  .encaminha {
    display: table !important;
    width: 100%;
    border-collapse: collapse;
    font-size: 9pt;
    page-break-inside: auto;
  }
  .encaminha thead {
    display: table-header-group !important;
    background: #0B203C !important;
    color: white !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .encaminha thead tr {
    background: #0B203C !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .encaminha th {
    color: white !important;
    padding: 2mm 3mm;
    font-size: 8.5pt;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .encaminha tbody { display: table-row-group !important; }
  .encaminha tr { display: table-row !important; page-break-inside: avoid; }
  .encaminha tbody tr:nth-child(even) {
    background: #f7f7f7 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .encaminha td {
    display: table-cell !important;
    padding: 2mm 3mm !important;
    border: 0 !important;
    border-top: 0.5pt solid #e2e8f0 !important;
    font-size: 9pt;
  }
  .encaminha td::before { content: none !important; }
  .encaminha td:first-child { font-weight: 600; }
  .encaminha td.contato { font-family: ui-monospace, monospace; color: #01579B; font-weight: 600; }
  .encaminha td.danger {
    color: #DC2626 !important;
    background: #fef2f2 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    font-weight: 700;
  }

  /* INSTITUIÇÕES: 2 colunas */
  .grid, .grid-2, .grid-4 {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 2mm !important;
  }
  .inst-card { padding: 2.5mm 3mm; }
  .inst-card h4 { font-size: 10.5pt; }
  .inst-card .sigla { font-size: 8pt; color: #0288D1; }
  .inst-card .desc { font-size: 9pt; }

  /* Filmes */
  .filmes { grid-template-columns: repeat(2, 1fr) !important; gap: 2mm !important; }
  .filme { padding: 2.5mm 3mm; }
  .filme h4 { font-size: 10.5pt; }
  .filme p { font-size: 9pt; }

  /* Bibliografia */
  .biblio li {
    padding: 2mm 3mm;
    font-size: 9.5pt;
    line-height: 1.4;
    margin-bottom: 1mm;
  }

  /* Divider */
  .divider { margin-block: 5mm; }

  /* Callouts */
  .callout {
    padding: 2.5mm 4mm;
    margin: 3mm 0;
    background: #fafafa !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .callout--warning {
    background: #fef3c7 !important;
    border-left-color: #D97706 !important;
  }
  .callout--danger {
    background: #fee2e2 !important;
    border-left-color: #DC2626 !important;
  }
  .callout p { font-size: 9.5pt; }
  .callout h4 { font-size: 10.5pt; }
  .callout-icon { width: 5mm; height: 5mm; min-width: 5mm; }

  /* CONSIDERAÇÕES FINAIS centradas */
  section.container-narrow {
    text-align: center;
    padding-block: 6mm !important;
    page-break-before: auto;
  }

  /* FOOTER unificado e contido */
  footer {
    background: white !important;
    color: var(--c-text) !important;
    padding-block: 5mm !important;
    margin-top: 6mm !important;
    border-top: 1pt solid #d4d4d4;
    page-break-inside: avoid;
  }
  footer h3 { color: var(--c-text) !important; font-size: 10pt; margin-bottom: 1mm; }
  footer p { color: var(--c-text-muted) !important; font-size: 9pt; margin-bottom: 1mm; }
  footer a { color: #0288D1 !important; }
  .footer-logo { display: none !important; }
  .footer-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 4mm !important;
    margin-bottom: 4mm !important;
  }
  .emerg-n { color: #0288D1 !important; }
  .emerg-l { color: var(--c-text) !important; }
  .creditos {
    background: #fafafa !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    border: 0.5pt solid #d4d4d4;
    padding: 3mm 4mm !important;
  }
  .creditos-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 4mm !important; }
  .creditos-h { color: var(--c-text) !important; font-size: 10pt; }
  .creditos p { color: var(--c-text) !important; font-size: 9pt; }
  .creditos .crp { color: #666 !important; font-size: 8pt; }

  /* Esconde o "Considerações finais" callout? Não, deixa visível. Mas o callout "Como navegar pelo guia" sim. */
  /* Já tratado por .callout--success { display: none } no topo */
}

/* ---------- 18. MOBILE FINE TUNING ---------- */
@media (max-width: 640px) {
  /* TOPBAR: compacta para caber em 375px */
  .topbar-inner { padding-block: 10px; min-height: 56px; gap: 8px; }
  .brand img { width: 32px; height: 32px; }
  .brand-text strong { font-size: 0.9375rem; line-height: 1.15; }
  .brand-text small { display: none; }

  /* Link "terapeutamultimidia.com.br": vira só seta com aria-label */
  .topbar-actions .btn-ghost span { display: none; }
  .topbar-actions .btn-ghost { padding: 10px; min-width: 44px; justify-content: center; }

  /* Botão "Baixar PDF": só ícone em mobile pequeno */
  .topbar-actions .btn-primary span { display: none; }
  .topbar-actions .btn-primary { padding: 10px; min-width: 44px; justify-content: center; }

  /* TABS: padding menor, sticky alinhado com topbar nova */
  .tabs-wrap { top: 56px; }
  .tabs { padding-block: 6px; gap: 2px; }
  .tab { padding: 10px 12px; font-size: var(--fs-xs); gap: 8px; }
  .tab .num { width: 20px; height: 20px; font-size: 0.6875rem; }

  /* HERO: mais compacto */
  .hero { padding-block: 32px; }
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn-primary, .hero-cta .btn-ghost { justify-content: center; }
  .hero-eyebrow { font-size: 0.6875rem; padding: 5px 10px; }
  .hero-visual { padding: 16px 0 0; }
  .hero-visual picture { max-width: 340px; }

  /* TIPOGRAFIA mobile */
  h2 { font-size: 1.625rem; line-height: 1.15; }
  h3 { font-size: 1.25rem; margin-block: 24px 10px; }
  .lede { font-size: 1rem; }

  /* CITAÇÃO */
  .quote {
    padding: 24px 20px 20px;
    margin-block: 24px;
    font-size: 1.0625rem;
    line-height: 1.45;
  }
  .quote::before { font-size: 3rem; top: -2px; left: 12px; }

  /* TABELA: vira lista de cards (mobile-friendly) */
  .encaminha-wrap { border: 0; background: transparent; overflow: visible; }
  .encaminha { display: block; }
  .encaminha thead { display: none; }
  .encaminha tbody, .encaminha tr, .encaminha td { display: block; }
  .encaminha tr {
    background: var(--c-bg-card);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-md);
    padding: 16px 18px;
    margin-bottom: 12px;
  }
  .encaminha tbody tr:nth-child(even) { background: var(--c-bg-card); }
  .encaminha td { padding: 0; border: 0; }
  .encaminha td:first-child {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--c-text);
    margin-bottom: 6px;
    line-height: 1.3;
  }
  .encaminha td:nth-child(2) {
    font-size: var(--fs-sm);
    color: var(--c-text-muted);
    margin-bottom: 6px;
  }
  .encaminha td:nth-child(2)::before {
    content: 'Encaminhar para → ';
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--c-primary-strong);
    text-transform: uppercase;
    display: block;
    margin-bottom: 2px;
  }
  .encaminha td.contato {
    font-size: var(--fs-sm);
    padding-top: 6px;
    border-top: 1px dashed var(--c-border);
    margin-top: 4px;
  }
  .encaminha td.contato::before {
    content: 'Contato ';
    font-family: var(--font-body);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--c-primary-strong);
    text-transform: uppercase;
    display: block;
    margin-bottom: 2px;
  }
  .encaminha td.danger { color: var(--c-danger); border-top-color: var(--c-danger-soft); }

  /* CARDS: padding menor */
  .card, .lei, .cond-card, .nivel { padding: 20px; }
  .nivel { padding: 18px; }
  .nivel-svg, .nivel-img { max-width: 200px; }
  .acao { padding: 16px 18px; gap: 14px; }
  .acao-num { width: 36px; height: 36px; font-size: 1rem; }

  /* CALLOUTS */
  .callout { padding: 16px 18px; gap: 12px; }
  .callout-icon { width: 22px; height: 22px; }

  /* FOOTER */
  footer { padding-block: 40px; }
  .footer-grid { gap: 24px; margin-bottom: 28px; }

  /* CREDITOS */
  .creditos-grid { gap: 20px; }
  .creditos-h { font-size: 1rem; margin-bottom: 8px; }
}

/* iPhone SE muito pequeno */
@media (max-width: 380px) {
  .tab span:not(.num) { display: none; }
  .tab { padding: 10px 12px; }
  .tab .num { width: 26px; height: 26px; font-size: 0.8125rem; }
  .container { padding-inline: 14px; }
  .hero-title { font-size: 2rem; }
}
