@font-face {
  font-family: 'InterVar';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('https://rsms.me/inter/font-files/InterVariable.woff2?v=4.1') format('woff2');
}

:root {
  font-family: 'Elza', InterVar, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial;
}

/* Preview compacto, sem scroll próprio */
#preview {
  width: 100%;
  height: auto;
  max-width: 420px;
}

#previewWrap {
  max-width: 420px;
  overflow: visible;
}

@media (max-width: 640px) {
  #preview,
  #previewWrap {
    max-width: 92vw;
  }
}

/* Fundo quadriculado discreto */
#previewBg {
  position: relative;
}

#previewBg::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: repeating-conic-gradient(#f3f4f6 0% 25%, #e5e7eb 0% 50%) 50% / 20px 20px;
  z-index: 0;
}

#previewBg > * {
  position: relative;
  z-index: 1;
}

#cropArea {
  position: relative;
  aspect-ratio: 1 / 1;
  min-height: 280px;
}

#cropArea::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: repeating-conic-gradient(#f3f4f6 0% 25%, #e5e7eb 0% 50%) 50% / 24px 24px;
  z-index: 0;
}

#cropArea > * {
  position: relative;
  z-index: 1;
}

#cropArea img {
  max-width: 100%;
  max-height: 100%;
  height: auto;
  display: block;
}
