/* ── VARIABLES ── */
:root {
  --red: #E8352A;
  --red-dark: #C42D22;
  --red-light: #FFF0EF;
  --green: #4A7C3F;
  --green-dark: #2D6E26;
  --green-light: #EEF5EC;
  --warm-white: #FFFAF9;
  --near-black: #1A1A1A;
  --warm-gray: #6B6B6B;
  --border: #E8E0DF;
  --white: #FFFFFF;
  --yellow: #F5A623;
  --shadow-red: rgba(232, 53, 42, 0.18);
}

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

html { scroll-behavior: smooth; }

body {
  font-family: 'Poppins', sans-serif;
  background: var(--warm-white);
  color: var(--near-black);
  font-size: 16px;
  line-height: 1.5;
  min-height: 100vh;
}

img { display: block; }

button, input, textarea, select {
  font-family: 'Poppins', sans-serif;
}

/* ── FOCUS STYLES ── */
:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 4px;
  border-radius: 4px;
}

/* ── KEYFRAMES ── */
@keyframes tomatoFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}

@keyframes bgFloat {
  0%, 100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
  50%       { transform: translateY(var(--drift, -8px)) rotate(var(--rot, 0deg)); }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

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

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

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

@keyframes slideInRight {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}

@keyframes slideInUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

@keyframes checkmarkAppear {
  from { opacity: 0; transform: scale(0.4); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes iconPop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.2); }
  100% { transform: scale(1); }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-6px); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(-4px); }
  80%       { transform: translateX(4px); }
}

@keyframes tomatoPop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.15); }
  70%  { transform: scale(0.95); }
  100% { transform: scale(1); }
}

@keyframes ripple {
  0%   { transform: scale(0.5); opacity: 0.7; }
  100% { transform: scale(2.5); opacity: 0; }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}

@keyframes breathe {
  0%   { transform: scale(0.85); }
  45%  { transform: scale(1.15); }
  55%  { transform: scale(1.15); }
  100% { transform: scale(0.85); }
}

/* ── UTILITIES ── */
.hidden { display: none !important; }

.spin {
  animation: spin 0.8s linear infinite;
  display: inline-block;
}

.fade-in-up {
  animation: fadeInUp 0.4s ease-out both;
}

.shake { animation: shake 0.4s ease; }
