* {
  scroll-behavior: smooth;
}

body {
  font-family:
    Inter,
    ui-sans-serif,
    system-ui,
    -apple-system,
    Segoe UI,
    Roboto,
    Helvetica,
    Arial,
    "Apple Color Emoji",
    "Segoe UI Emoji";
}

.widget-root input:not([type="checkbox"]):not([type="radio"]),
.widget-root select {
  width: 100%;
  background: #ffffff;
  color: #1f2937;
}

.dark .widget-root input:not([type="checkbox"]):not([type="radio"]),
.dark .widget-root select {
  background: #0f172a;
  color: #e2e8f0;
  border-color: #334155;
}

.prose p {
  line-height: 1.7;
}

.prose strong {
  font-weight: 600;
}

/* CLS reserve: prevents layout shift while Svelte widgets load.
   main.js removes this inline style after mounting. */
.widget-root {
  min-height: 420px;
}

/* ── Print / Baixar PDF ─────────────────────────────────────────────────── */
@media print {
  aside,
  header,
  footer,
  .print\:hidden {
    display: none !important;
  }

  .md\:ml-80 {
    margin-left: 0 !important;
  }

  main {
    padding: 0 !important;
    max-width: 100% !important;
  }

  pre,
  table,
  figure {
    break-inside: avoid;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 0.75em;
    color: #555;
  }

  a[href^="/"]::after,
  a[href^="#"]::after {
    content: none;
  }
}
