@tailwind base;
@tailwind components;
@tailwind utilities;

/* Custom styles for Stryde */

/* Prevent overscroll bounce on mobile Chrome */
html,
body {
  overscroll-behavior-y: none;
}

/* Form input focus styles */
input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: rgba(42, 157, 143, 0.6) !important;
  box-shadow: 0 0 0 1px rgba(42, 157, 143, 0.3);
}

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

::-webkit-scrollbar-track {
  background: rgba(245, 245, 245, 0.5);
}

::-webkit-scrollbar-thumb {
  background: rgba(76, 181, 165, 0.5);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(76, 181, 165, 0.7);
}

/* Hide scrollbar utility */
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

/* Animation keyframes */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in {
  animation: fadeIn 0.3s ease-out;
}

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

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

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

.animate-float-slow {
  animation: floatSlow 12s ease-in-out infinite;
}

.animate-float-medium {
  animation: floatMedium 9s ease-in-out infinite;
}

.animate-float-fast {
  animation: floatFast 6s ease-in-out infinite;
}

/* Line clamp utilities */
.line-clamp-1 {
  display: -webkit-box;
  line-clamp: 1;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-2 {
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Prose styles for episode descriptions */
.prose p {
  margin-bottom: 1em;
}

.prose a {
  color: #4cb5a5;
  text-decoration: underline;
}

.prose a:hover {
  color: #2a9d8f;
}

/* Safe area padding for notched mobile devices */
.safe-area-inset {
  padding-top: env(safe-area-inset-top, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* Overlay swipe performance */
#recommendation-overlay-panel [data-recommendation-overlay-target='viewport'] {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Prevent image dragging/selection from interfering with swipe */
#recommendation-overlay-panel img {
  -webkit-user-drag: none;
  user-select: none;
}

/* Skip rendering off-screen slides */
#recommendation-overlay-panel [data-recommendation-overlay-target='card'] {
  content-visibility: auto;
  contain-intrinsic-size: 100vw auto;
}

/* Disable overlay transitions for reduced-motion users */
@media (prefers-reduced-motion: reduce) {
  #recommendation-overlay-panel,
  #recommendation-overlay-panel
    [data-recommendation-overlay-target='viewport'] {
    transition: none !important;
  }

  .animate-float-slow,
  .animate-float-medium,
  .animate-float-fast {
    animation: none !important;
  }
}
