@import url('https://fonts.googleapis.com/css2?family=Bangers&family=Nunito:wght@400;700;900&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Nunito', sans-serif;
  background: #1a1a2e;
  min-height: 100vh;
  overflow-x: hidden;
}

body.light-mode {
  background: #FFF8E7;
}

@keyframes wiggle {
  0%, 100% { transform: rotate(0deg); }
  15% { transform: rotate(14deg); }
  30% { transform: rotate(-10deg); }
  45% { transform: rotate(8deg); }
  60% { transform: rotate(-6deg); }
  75% { transform: rotate(3deg); }
}

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-8px); }
}

@keyframes spin-banana {
  0% { transform: rotate(0deg) scale(1); }
  25% { transform: rotate(90deg) scale(1.1); }
  50% { transform: rotate(180deg) scale(1); }
  75% { transform: rotate(270deg) scale(1.1); }
  100% { transform: rotate(360deg) scale(1); }
}

@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 20px rgba(255,225,53,0.3); }
  50% { box-shadow: 0 0 40px rgba(255,225,53,0.6), 0 0 60px rgba(255,159,28,0.3); }
}

@keyframes confetti-fall {
  0% { transform: translateY(-100vh) rotate(0deg); opacity: 1; }
  100% { transform: translateY(100vh) rotate(720deg); opacity: 0; }
}

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

@keyframes gradient-shift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.wiggle-banana {
  display: inline-block;
  animation: wiggle 2s ease-in-out infinite;
}

.float-anim {
  animation: float 3s ease-in-out infinite;
}

.spin-banana {
  animation: spin-banana 1.2s linear infinite;
  display: inline-block;
  font-size: 3rem;
}

.pulse-btn {
  animation: pulse-glow 2s ease-in-out infinite;
}

.slide-up {
  animation: slide-up 0.5s ease-out;
}

.gradient-header {
  background: linear-gradient(135deg, #FFE135, #FF9F1C, #FF6B35, #FFE135);
  background-size: 300% 300%;
  animation: gradient-shift 4s ease infinite;
}

.meme-text-top, .meme-text-bottom {
  font-family: 'Bangers', Impact, sans-serif;
  letter-spacing: 2px;
  line-height: 1.1;
  word-wrap: break-word;
  text-transform: uppercase;
}

.meme-canvas-wrapper {
  position: relative;
  display: inline-block;
  max-width: 100%;
}

.meme-canvas-wrapper img {
  display: block;
  max-width: 100%;
  border-radius: 8px;
}

.meme-overlay {
  position: absolute;
  left: 0;
  right: 0;
  padding: 12px 16px;
  text-align: center;
  pointer-events: none;
}

.meme-overlay-top {
  top: 0;
}

.meme-overlay-bottom {
  bottom: 0;
}

.confetti-piece {
  position: fixed;
  width: 12px;
  height: 12px;
  top: -20px;
  animation: confetti-fall 2.5s linear forwards;
  z-index: 9999;
  pointer-events: none;
}

.gallery-thumb {
  transition: transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
}

.gallery-thumb:hover {
  transform: scale(1.08);
  box-shadow: 0 8px 24px rgba(255,225,53,0.4);
}

.gen-btn {
  transition: transform 0.15s, box-shadow 0.15s;
}

.gen-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 30px rgba(255,225,53,0.5);
}

.gen-btn:active {
  transform: scale(0.97);
}

/* Scrollbar styling */
::-webkit-scrollbar {
  height: 8px;
  width: 8px;
}

::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: #FFE135;
  border-radius: 4px;
}

.template-card {
  transition: all 0.2s;
  cursor: pointer;
}

.template-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255,225,53,0.3);
  border-color: #FFE135 !important;
}

input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  background: linear-gradient(to right, #FFE135, #FF9F1C);
  border-radius: 3px;
  outline: none;
}

input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  background: #FFE135;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}