/**
 * Responsividade total - mobile-first até desktop
 * Breakpoints: 320px (xs) | 360px (sm) | 768px (md) | 1024px (lg)
 */

/* === BASE: telas muito pequenas (320px+) === */
html {
  font-size: 14px;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* === SM: 360px+ === */
@media (min-width: 360px) {
  html {
    font-size: 15px;
  }
}

/* === MD: 768px+ === */
@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

/* === LG: 1024px+ === */
@media (min-width: 1024px) {
  html {
    font-size: 16px;
  }
}

/* === Tipografia fluida === */
.text-fluid-xs { font-size: clamp(0.6875rem, 2vw, 0.75rem); }
.text-fluid-sm { font-size: clamp(0.8125rem, 2.5vw, 0.875rem); }
.text-fluid-base { font-size: clamp(0.875rem, 2.5vw, 1rem); }
.text-fluid-lg { font-size: clamp(1rem, 3vw, 1.125rem); }
.text-fluid-xl { font-size: clamp(1.125rem, 3.5vw, 1.25rem); }
.text-fluid-2xl { font-size: clamp(1.25rem, 4vw, 1.5rem); }
.text-fluid-3xl { font-size: clamp(1.5rem, 5vw, 2rem); }
.text-fluid-4xl { font-size: clamp(1.75rem, 6vw, 2.5rem); }
.text-fluid-5xl { font-size: clamp(2rem, 8vw, 3rem); }
.text-fluid-6xl { font-size: clamp(2.25rem, 10vw, 4rem); }

/* === Espaçamento responsivo === */
.p-safe { padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left); }
.px-safe { padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); }
.pb-safe { padding-bottom: env(safe-area-inset-bottom); }
.pt-safe { padding-top: env(safe-area-inset-top); }

/* === Scene: padding adaptativo === */
.scene {
  padding-left: max(1rem, env(safe-area-inset-left));
  padding-right: max(1rem, env(safe-area-inset-right));
  padding-top: max(1rem, env(safe-area-inset-top));
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
}

@media (min-width: 360px) {
  .scene {
    padding-left: max(1.25rem, env(safe-area-inset-left));
    padding-right: max(1.25rem, env(safe-area-inset-right));
  }
}

@media (min-width: 768px) {
  .scene {
    padding-left: max(1.5rem, env(safe-area-inset-left));
    padding-right: max(1.5rem, env(safe-area-inset-right));
  }
}

/* === Containers com max-width para telas grandes === */
.container-scene {
  width: 100%;
  max-width: 28rem;
}

@media (min-width: 768px) {
  .container-scene {
    max-width: 32rem;
  }
}

@media (min-width: 1024px) {
  .container-scene {
    max-width: 36rem;
  }
}

/* === Altura mínima segura (mobile viewport) === */
.min-h-safe {
  min-height: 100vh; /* fallback */
  min-height: 100dvh;
}

/* === Botões: responsivo em telas pequenas === */
@media (max-width: 359px) {
  button, .touch-target {
    min-height: 48px;
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: 0.9375rem;
  }
}

/* === Overflow e scroll === */
.overflow-x-hidden {
  overflow-x: hidden;
}

/* === Telas muito curtas (landscape mobile) === */
@media (max-height: 500px) {
  .scene {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
  [data-final-content] {
    padding-bottom: 1rem;
  }
  [data-final-btns] {
    flex-wrap: wrap;
    gap: 0.5rem;
    padding-top: 0.5rem;
  }
}

