/* ============================================================
   Arraiá da Kamilly — Design System Global
   Paleta, tipografia, tokens, reset e utilitários
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Chewy&family=Lilita+One&family=Fredoka:wght@300;400;500;600&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

/* ─── CSS Custom Properties (Design Tokens) ─────────────────── */
:root {
  /* Cores temáticas */
  --cream:        #FFFDF6;
  --sand:         #FAF3E5;
  --terracotta:   #C84B22;
  --terracotta-dark: #A03A18;
  --terracotta-light: #E8623A;
  --brown-dark:   #4A220F;
  --brown-medium: #7A3A1A;
  --gold:         #EFA31E;
  --gold-light:   #F7C855;
  --green:        #206F3D;
  --green-light:  #D1FAE5;
  --green-medium: #34A85A;
  --red:          #DC2626;
  --red-light:    #FEE2E2;

  /* Tipografia */
  --font-display: 'Chewy', cursive;
  --font-heading: 'Lilita One', sans-serif;
  --font-sub:     'Fredoka', sans-serif;
  --font-body:    'Plus Jakarta Sans', sans-serif;

  /* Sombras */
  --shadow-sm:    0 2px 8px rgba(74, 34, 15, 0.12);
  --shadow-md:    0 4px 20px rgba(74, 34, 15, 0.18);
  --shadow-lg:    0 8px 40px rgba(74, 34, 15, 0.22);
  --shadow-3d:    0 6px 0 var(--terracotta-dark);
  --shadow-3d-gold: 0 6px 0 #C07A10;

  /* Bordas */
  --radius-sm:    8px;
  --radius-md:    16px;
  --radius-lg:    24px;
  --radius-xl:    32px;
  --radius-full:  9999px;

  /* Espaçamento */
  --space-xs:     4px;
  --space-sm:     8px;
  --space-md:     16px;
  --space-lg:     24px;
  --space-xl:     32px;
  --space-2xl:    48px;

  /* Transições */
  --transition-fast:   0.15s ease;
  --transition-smooth: 0.3s ease;
  --transition-slow:   0.5s ease;
}

/* ─── Reset & Base ───────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  background-color: var(--sand);
  color: var(--brown-dark);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
}

img, svg {
  display: block;
  max-width: 100%;
}

button {
  cursor: pointer;
  font-family: inherit;
  border: none;
  background: none;
}

input, textarea, select {
  font-family: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ─── Tipografia Utilitária ──────────────────────────────────── */
.font-display  { font-family: var(--font-display); }
.font-heading  { font-family: var(--font-heading); }
.font-sub      { font-family: var(--font-sub); }
.font-body     { font-family: var(--font-body); }

/* ─── Cores Utilitárias ──────────────────────────────────────── */
.text-terracotta { color: var(--terracotta); }
.text-brown      { color: var(--brown-dark); }
.text-gold       { color: var(--gold); }
.text-green      { color: var(--green); }
.text-red        { color: var(--red); }

/* ─── Botão Principal (Terracota 3D) ────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: 16px 32px;
  min-height: 56px;
  background: var(--terracotta);
  color: var(--cream);
  font-family: var(--font-heading);
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-3d);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

.btn-primary:hover {
  background: var(--terracotta-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 0 var(--terracotta-dark);
}

.btn-primary:active {
  transform: translateY(4px);
  box-shadow: 0 2px 0 var(--terracotta-dark);
}

/* ─── Botão Secundário (Ouro 3D) ─────────────────────────────── */
.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: 14px 28px;
  min-height: 52px;
  background: var(--gold);
  color: var(--brown-dark);
  font-family: var(--font-heading);
  font-size: 1rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-3d-gold);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

.btn-secondary:hover {
  background: var(--gold-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 0 #C07A10;
}

.btn-secondary:active {
  transform: translateY(4px);
  box-shadow: 0 2px 0 #C07A10;
}

/* ─── Botão Ghost ────────────────────────────────────────────── */
.btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: 12px 24px;
  min-height: 48px;
  background: transparent;
  color: var(--terracotta);
  font-family: var(--font-sub);
  font-size: 0.95rem;
  font-weight: 500;
  border: 2px solid var(--terracotta);
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}

.btn-ghost:hover {
  background: var(--terracotta);
  color: var(--cream);
}

/* ─── Card Base ─────────────────────────────────────────────── */
.card {
  background: var(--cream);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
}

/* ─── Badge de Presença ─────────────────────────────────────── */
.badge-yes {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  background: var(--green-light);
  color: var(--green);
  font-family: var(--font-sub);
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.badge-no {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  background: var(--red-light);
  color: var(--red);
  font-family: var(--font-sub);
  font-weight: 600;
  font-size: 0.85rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

/* ─── Input Base ────────────────────────────────────────────── */
.input-field {
  width: 100%;
  padding: 14px 18px;
  background: var(--cream);
  border: 2px solid var(--brown-dark);
  border-radius: var(--radius-md);
  font-family: var(--font-sub);
  font-size: 1rem;
  color: var(--brown-dark);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
  min-height: 52px;
}

.input-field::placeholder {
  color: rgba(74, 34, 15, 0.4);
}

.input-field:focus {
  border-color: var(--terracotta);
  box-shadow: 0 0 0 3px rgba(200, 75, 34, 0.15);
}

/* ─── Borda Rústica Tracejada ───────────────────────────────── */
.border-rustic {
  border: 2px dashed var(--brown-dark);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

/* ─── Animações ─────────────────────────────────────────────── */
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-12px); }
}

@keyframes sway {
  0%, 100% { transform: rotate(-3deg); }
  50%       { transform: rotate(3deg); }
}

@keyframes flicker {
  0%, 100% { transform: scale(1) translateY(0); opacity: 1; }
  25%       { transform: scale(1.05) translateY(-2px); opacity: 0.95; }
  50%       { transform: scale(0.97) translateY(1px); opacity: 1; }
  75%       { transform: scale(1.03) translateY(-1px); opacity: 0.98; }
}

@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 10px rgba(239, 163, 30, 0.4); }
  50%       { box-shadow: 0 0 25px rgba(239, 163, 30, 0.8); }
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.8); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes bandeirinhas-sway {
  0%   { transform: rotate(-1deg) translateY(0px); }
  50%  { transform: rotate(1deg) translateY(2px); }
  100% { transform: rotate(-1deg) translateY(0px); }
}

.animate-slide-up    { animation: slideUp var(--transition-smooth) forwards; }
.animate-fade-in     { animation: fadeIn var(--transition-smooth) forwards; }
.animate-scale-in    { animation: scaleIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; }
.animate-float       { animation: float 3s ease-in-out infinite; }

/* ─── Scrollbar Personalizada ───────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--sand); }
::-webkit-scrollbar-thumb { background: var(--terracotta); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--terracotta-dark); }

/* ─── Utilitários de Layout ─────────────────────────────────── */
.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-sm       { gap: var(--space-sm); }
.gap-md       { gap: var(--space-md); }
.gap-lg       { gap: var(--space-lg); }
.w-full       { width: 100%; }
.text-center  { text-align: center; }
.hidden       { display: none !important; }
