@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
  /* Light Theme (Default) */
  --bg-primary: #f8f9fa;
  --bg-secondary: #ffffff;
  --text-primary: #1a1a1a;
  --text-secondary: #43465e;
  --accent: #e50914;
  --accent-hover: #b20710;
  --accent-brand: #c1071e;
  --card-bg: #ffffff;
  --border: #dedede;
  --nav-bg: rgba(255, 255, 255, 0.9);
}

body.dark-theme {
  /* Dark Theme (Netflix Style) */
  --bg-primary: #131834;
  --bg-secondary: #0b0f24;
  --text-primary: #ffffff;
  --text-secondary: #dedede;
  --accent: #e50914;
  --accent-hover: #b20710;
  --accent-brand: #c1071e;
  --card-bg: #1e2445;
  --border: #43465e;
  --nav-bg: rgba(19, 24, 52, 0.9);
}

* { 
    transition: background-color 0.3s ease, 
                border-color 0.3s ease,
                color 0.3s ease; 
}

body {
  font-family: 'Poppins', sans-serif;
  background-color: var(--bg-primary);
  color: var(--text-primary);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Bottom Navigation (Mobile) */
.bottom-nav {
  display: none;
}
@media (max-width: 1023px) {
  .bottom-nav {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: var(--nav-bg);
    backdrop-filter: blur(10px);
    border-top: 1px solid var(--border);
    z-index: 50;
  }
  body {
    padding-bottom: 60px; /* Space for bottom nav */
  }
}

/* Cards modernos */
.card {
  background-color: var(--card-bg);
  border-radius: 4px;
  border: 1px solid var(--border);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

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

/* Line Clamp */
.line-clamp-1 {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;  
    overflow: hidden;
}
.line-clamp-2 {
    display: -webkit-box;
    -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;
}

/* Netflix Carousel Hover Effects */
.carousel-item {
    transition: transform 0.3s ease, z-index 0.3s ease;
}
.carousel-item:hover {
    transform: scale(1.05) translateY(-4px);
    z-index: 50;
    box-shadow: 0 10px 20px rgba(0,0,0,0.5);
}
.carousel-item-details {
    opacity: 0;
    transition: opacity 0.3s ease;
}
.carousel-item:hover .carousel-item-details {
    opacity: 1;
}

/* Floating Label */
.floating-input:focus ~ .floating-label,
.floating-input:not(:placeholder-shown) ~ .floating-label {
    transform: translateY(-1rem) scale(0.75);
}

/* Shimmer Effect for Skeleton Loading */
@keyframes shimmer {
  0% {
    background-position: -1000px 0;
  }
  100% {
    background-position: 1000px 0;
  }
}
.skeleton {
  animation: shimmer 2s infinite linear;
  background: linear-gradient(to right, var(--card-bg) 4%, var(--border) 25%, var(--card-bg) 36%);
  background-size: 1000px 100%;
}
