/* Portal Enhanced Styles - Premium Design System */
:root {
  --theme-color:#2ddc43;
  --theme-secondary:#21c4b6;
  --gradient-primary:linear-gradient(135deg,#2ddc43 0%,#21c4b6 100%);
  --gradient-accent:linear-gradient(120deg,#2ddc43 0%,#1ea3d6 50%,#21c4b6 100%);
  --gradient-warm:linear-gradient(135deg,#ff6b6b 0%,#ffa726 100%);
  --bg-color:#0a0a0a;
  --surface-color:#141414;
  --surface-elevated:#1f1f1f;
  --surface-glass:rgba(255,255,255,0.02);
  --text-color:#f5f5f5;
  --text-secondary:#b8b8b8;
  --text-muted:#888;
  --border-color:rgba(255,255,255,0.08);
  --border-accent:rgba(45,220,67,0.3);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.15);
  --shadow-md:0 4px 16px rgba(0,0,0,0.25);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.35);
  --shadow-accent:0 8px 24px rgba(45,220,67,0.25);
  --radius-xs:6px;
  --radius-sm:10px;
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:24px;
  --transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
  --transition-fast:all 0.15s ease-out;
  --transition-slow:all 0.5s cubic-bezier(0.25,0.46,0.45,0.94);
}
html,body{
  height:100%;
  background:var(--bg-color);
  color:var(--text-color);
  font-family:'Prompt',sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  scroll-behavior:smooth;
}
body{
  background-image:
    radial-gradient(circle at 20% 80%, rgba(45,220,67,0.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(33,196,182,0.03) 0%, transparent 50%);
  background-attachment:fixed;
}
img{display:block;max-width:100%;height:auto}

.portal-header{
  position:sticky;
  top:0;
  z-index:60;
  backdrop-filter:blur(12px) saturate(1.2);
  background:rgba(10,10,10,0.85);
  border-bottom:1px solid var(--border-color);
  box-shadow:var(--shadow-sm);
  transition:var(--transition-fast);
}
.navbar-container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 .9rem;
  margin-bottom: 15px;
}
@media (min-width:768px){
  .navbar-container{
    padding:0;
  }
}
.portal-brand{
  display:flex;
  align-items:center;
  gap:.6rem;
  text-decoration:none;
  color:var(--text-color);
  font-weight:800;
  font-size:1.1rem;
  letter-spacing:0.5px;
  transition:var(--transition-fast);
  margin-left:0;
}
@media (min-width:768px){
  .portal-brand{
    margin-left:-.5rem;
  }
}
.portal-brand:hover{
  transform:translateY(-1px);
  filter:brightness(1.1);
}
.portal-brand-badge{
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-size:1.3rem;
  font-weight:900;
}
.portal-search{
  position:relative;
  max-width:580px;
  width:100%;
  margin:0 auto;
}
.portal-search input{
  width:100%;
  padding:.6rem 2.5rem .6rem 1rem;
  border-radius:var(--radius-md);
  border:1px solid var(--border-color);
  background:var(--surface-elevated);
  color:var(--text-color);
  font-size:.9rem;
  font-weight:500;
  transition:var(--transition);
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow-sm);
}
@media (min-width:576px){
  .portal-search input{
    padding:.65rem 2.6rem .65rem 1.1rem;
    font-size:.93rem;
    border-radius:var(--radius-lg);
  }
}
@media (min-width:768px){
  .portal-search input{
    padding:.7rem 2.8rem .7rem 1.2rem;
    font-size:.96rem;
  }
}
.portal-search input:focus{
  outline:0;
  border-color:var(--border-accent);
  box-shadow:0 0 0 3px rgba(45,220,67,0.15), var(--shadow-md);
  background:var(--surface-color);
}
.portal-search input::placeholder{
  color:var(--text-muted);
  font-weight:400;
}
.portal-search i{
  position:absolute;
  right:.8rem;
  top:50%;
  transform:translateY(-50%);
  color:var(--text-secondary);
  font-size:1rem;
  transition:var(--transition-fast);
}
@media (min-width:576px){
  .portal-search i{
    right:.85rem;
    font-size:1.05rem;
  }
}
@media (min-width:768px){
  .portal-search i{
    right:.9rem;
    font-size:1.1rem;
  }
}
.portal-search input:focus + i{
  color:var(--theme-color);
}

.portal-nav{
  display:flex;
  align-items:center;
  gap:.3rem;
}
.portal-nav a{
  color:var(--text-color);
  text-decoration:none;
  padding:.55rem .85rem;
  border-radius:var(--radius);
  font-weight:600;
  font-size:.88rem;
  transition:var(--transition);
  position:relative;
  letter-spacing:0.2px;
  white-space:nowrap;
  display:flex;
  align-items:center;
  gap:.4rem;
  border:1px solid transparent;
}
.portal-nav a:hover{
  background:var(--surface-elevated);
  color:var(--theme-color);
  border-color:var(--border-color);
}
.portal-nav a.active{
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:var(--shadow-accent);
  border-color:transparent;
}
.portal-nav a i{
  font-size:.9rem;
}

.category-scroll{
  display:flex;
  gap:.6rem;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:.6rem .3rem;
}
.category-scroll::-webkit-scrollbar{
  display:none;
}
.category-chip{
  flex:0 0 auto;
  padding:.55rem 1.1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  color:var(--text-color);
  text-decoration:none;
  background:rgba(255,255,255,0.05);
  font-size:.82rem;
  font-weight:600;
  white-space:nowrap;
  transition:var(--transition);
  backdrop-filter:blur(12px);
  letter-spacing:0.2px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1), 
             0 2px 8px rgba(0,0,0,0.15);
  position:relative;
  overflow:hidden;
  min-width:fit-content;
}
.category-chip:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, 
    rgba(255,255,255,0.08) 0%, 
    transparent 50%);
  opacity:0;
  transition:var(--transition);
}
.category-chip:hover{
  border-color:rgba(45,220,67,0.4);
  background:rgba(45,220,67,0.12);
  color:var(--theme-color);
  transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.15), 
             0 6px 20px rgba(45,220,67,0.25);
}
.category-chip:hover:before{
  opacity:1;
}
.category-chip.active{
  border-color:transparent;
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.2), 
             0 8px 24px rgba(45,220,67,0.4);
}
.category-chip.active:hover{
  transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.25), 
             0 10px 32px rgba(45,220,67,0.5);
}

.portal-container{
  max-width:1650px;
  margin:0 auto;
  padding:1rem .5rem 2rem;
  overflow-x:hidden;
}
@media (min-width:576px){
  .portal-container{
    padding:1.1rem .55rem 2.2rem;
  }
}
@media (min-width:768px){
  .portal-container{
    padding:1.5rem .9rem 3rem;
  }
}
@media (min-width:992px){
  .portal-container{
    padding:1.2rem .6rem 2.5rem;
  }
}
.movie-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.8rem;
  margin-top:1rem;
}
@media (min-width:576px){
  .movie-grid{
    grid-template-columns:repeat(3,1fr);
    gap:.9rem;
  }
}
@media (min-width:768px){
  .movie-grid{
    grid-template-columns:repeat(4,1fr);
    gap:1rem;
  }
  .portal-container{
    padding:1.5rem .9rem 3rem;
  }
}
@media (min-width:992px){
  .movie-grid{
    grid-template-columns:repeat(6,1fr);
    gap:1rem;
  }
}
@media (min-width:1200px){
  .movie-grid{
    grid-template-columns:repeat(6,1fr);
    gap:1.1rem;
  }
}
@media (min-width:1400px){
  .movie-grid{
    grid-template-columns:repeat(6,1fr);
    gap:1.2rem;
  }
}

.movie-card{
  background:transparent;
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  transition:var(--transition);
  cursor:pointer;
}
.movie-card:focus-within{
  outline:2px solid var(--border-accent);
  outline-offset:3px;
}
.movie-card:hover{
  transform:translateY(-4px) scale(1.02);
  filter:drop-shadow(var(--shadow-lg));
}
.thumb-wrap{
  position:relative;
  width:100%;
  aspect-ratio:231/346;
  background:linear-gradient(135deg, #1a1a1a, #0f0f0f);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border:1px solid var(--border-color);
}
.thumb{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition-slow);
  filter:brightness(0.9) contrast(1.05) saturate(1.1);
}
.movie-card:hover .thumb{
  transform:scale(1.08);
  filter:brightness(1) contrast(1.1) saturate(1.2);
}

.thumb-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,0.95);
  font-size:3.8rem;
  opacity:0;
  background:linear-gradient(135deg, 
    rgba(45,220,67,0.15) 0%, 
    rgba(0,0,0,0.4) 30%, 
    rgba(33,196,182,0.15) 100%);
  backdrop-filter:blur(2px);
  transition:var(--transition);
  transform:scale(0.8);
}
.movie-card:hover .thumb-overlay{
  opacity:1;
  transform:scale(1);
}
.thumb-overlay i{
  filter:drop-shadow(0 4px 12px rgba(0,0,0,0.6));
  animation:pulse-play 2s ease-in-out infinite;
}
@keyframes pulse-play{
  0%, 100% { transform:scale(1); }
  50% { transform:scale(1.05); }
}

.badge-top-right{
  position:absolute;
  right:10px;
  top:10px;
  z-index:3;
  display:flex;
  align-items:center;
  gap:.4rem;
}
.badge-views,.badge-lang{
  background:rgba(0,0,0,0.7);
  color:#fff;
  padding:.2rem .6rem;
  border-radius:999px;
  font-size:.7rem;
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  line-height:1;
  border:1px solid rgba(255,255,255,0.15);
  backdrop-filter:blur(8px) saturate(1.3);
  font-weight:600;
  transition:var(--transition-fast);
  box-shadow:var(--shadow-sm);
}
.badge-lang{padding:.15rem .5rem;font-size:.65rem}
.badge-views:hover,.badge-lang:hover{
  background:rgba(0,0,0,0.85);
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
/* Generic pill utility */
.pill{
  background:rgba(0,0,0,0.65);
  color:#fff;
  padding:.18rem .6rem;
  border-radius:999px;
  font-size:.68rem;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  line-height:1;
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(6px) saturate(1.2);
  font-weight:600;
  transition:var(--transition-fast);
}
.pill-sm{padding:.12rem .5rem;font-size:.62rem}
.pill-accent{
  background:var(--gradient-primary);
  color:#fff;
  border:0;
  box-shadow:var(--shadow-accent);
}
.rank-badge-wrapper{
  position:absolute;
  left:10px;
  top:10px;
  z-index:3;
}

.thumb-title-bar{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:.6rem .65rem;
  background:linear-gradient(to top, 
    rgba(0,0,0,0.85) 0%, 
    rgba(0,0,0,0.6) 70%, 
    rgba(0,0,0,0.1) 100%);
  backdrop-filter:blur(8px) saturate(1.2);
  border-top:1px solid rgba(255,255,255,0.08);
  z-index:2;
  transition:var(--transition-fast);
}
.movie-card:hover .thumb-title-bar{
  background:linear-gradient(to top, 
    rgba(0,0,0,0.9) 0%, 
    rgba(0,0,0,0.7) 70%, 
    rgba(0,0,0,0.2) 100%);
}
.thumb-title{
  margin:0;
  color:#fff;
  font-weight:700;
  font-size:clamp(.84rem,2.2vw,.96rem);
  display:-webkit-box;
  line-clamp:2;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-shadow:0 2px 8px rgba(0,0,0,0.8);
  letter-spacing:0.3px;
  line-height:1.3;
}

/* Hero */
.portal-hero{margin-bottom:.9rem}
.hero-wrap{position:relative;border-radius:16px;overflow:hidden;background:#191919;box-shadow:0 8px 32px rgba(0,0,0,.35);min-height:140px}
.hero-wrap img{width:100%;height:auto}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.05),rgba(0,0,0,.65))}

/* SEO chips/card */
.seo-cards{display:grid;grid-template-columns:1fr;gap:.75rem;margin:.5rem 0 1.1rem}
@media (min-width:576px){.seo-cards{grid-template-columns:1fr;gap:.8rem}}
@media (min-width:768px){.seo-cards{grid-template-columns:repeat(2,1fr);gap:.85rem}}
@media (min-width:1200px){.seo-cards{grid-template-columns:repeat(3,1fr)}}
.seo-card{background:var(--surface-color);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.8rem;position:relative;overflow:hidden}
@media (min-width:576px){.seo-card{padding:.85rem;border-radius:13px}}
@media (min-width:768px){.seo-card{padding:.9rem;border-radius:14px}}
.seo-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(45,220,67,.08),transparent 70%);pointer-events:none}
.seo-title{display:flex;align-items:center;gap:.4rem;margin:0 0 .5rem;font-weight:700;font-size:.95rem}
@media (min-width:576px){.seo-title{gap:.45rem;font-size:.98rem;margin:0 0 .52rem}}
@media (min-width:768px){.seo-title{gap:.5rem;font-size:1rem;margin:0 0 .55rem}}
.seo-title .dot{width:7px;height:7px;border-radius:999px;background:var(--gradient-accent);box-shadow:0 0 0 2px rgba(45,220,67,.12)}
@media (min-width:576px){.seo-title .dot{width:7.5px;height:7.5px;box-shadow:0 0 0 2.5px rgba(45,220,67,.13)}}
@media (min-width:768px){.seo-title .dot{width:8px;height:8px;box-shadow:0 0 0 3px rgba(45,220,67,.15)}}
.seo-text{color:var(--text-secondary);font-size:.85rem;line-height:1.4;margin:0}
@media (min-width:576px){.seo-text{font-size:.87rem;line-height:1.45}}
@media (min-width:768px){.seo-text{font-size:.9rem;line-height:1.5}}
.seo-chips{display:flex;flex-wrap:wrap;gap:.35rem}
@media (min-width:576px){.seo-chips{gap:.38rem}}
@media (min-width:768px){.seo-chips{gap:.4rem}}
.seo-chip{padding:.25rem .55rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:#fff;background:rgba(255,255,255,.05);font-size:.7rem;font-weight:500;letter-spacing:.1px;transition:var(--transition);text-decoration:none}
@media (min-width:576px){.seo-chip{padding:.26rem .6rem;font-size:.71rem;letter-spacing:.15px}}
@media (min-width:768px){.seo-chip{padding:.28rem .65rem;font-size:.72rem;letter-spacing:.2px}}
.seo-chip:hover{background:rgba(45,220,67,.15);border-color:rgba(45,220,67,.5)}

/* Buttons */
.btn-green{background:var(--gradient-accent);color:#fff;border:0;font-weight:600;box-shadow:0 6px 18px rgba(33,196,182,.25);transition:var(--transition)}
.btn-green:hover{filter:brightness(1.06);transform:translateY(-2px);color:#fff;box-shadow:0 10px 28px rgba(33,196,182,.35)}
.rank-badge{
  font-weight:900;
  font-size:.88rem;
  background:var(--gradient-primary)!important;
  color:#fff!important;
  border:0;
  box-shadow:var(--shadow-accent), var(--shadow-md);
  padding:.25rem .65rem;
  border-radius:999px;
  letter-spacing:0.5px;
  transition:var(--transition-fast);
}
.rank-badge:hover{
  transform:scale(1.05);
  box-shadow:0 8px 32px rgba(45,220,67,0.4);
}

/* Mobile bottom nav */
.mobile-bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;background:rgba(15,15,15,.95);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.12);padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 20px rgba(0,0,0,.3)}
@media (max-width:767.98px){.mobile-bottom-nav{display:block}.portal-container{padding-bottom:90px}}
@media (max-width:575.98px){.portal-container{padding-bottom:85px}}
.mobile-bottom-nav .mobile-nav-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:.3rem;max-width:720px;margin:0 auto;padding:.5rem .6rem}
.mobile-nav-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.25rem;
  padding:.6rem .5rem;
  text-decoration:none;
  color:var(--text-secondary);
  border-radius:var(--radius-sm);
  font-size:.72rem;
  transition:var(--transition);
  font-weight:600;
  min-height:60px;
}
@media (max-width:575.98px){
  .mobile-nav-item{
    padding:.5rem .4rem;
    font-size:.7rem;
    gap:.2rem;
    min-height:55px;
  }
}
.mobile-nav-item i{
  font-size:1.4rem;
  margin-bottom:.05rem;
}
@media (max-width:575.98px){
  .mobile-nav-item i{
    font-size:1.3rem;
    margin-bottom:.1rem;
  }
}
.mobile-nav-item.active{
  color:#fff;
  background:var(--gradient-primary);
  box-shadow:var(--shadow-accent);
}
.mobile-nav-item:hover{
  color:var(--theme-color);
  background:var(--surface-elevated);
}
.mobile-nav-item:focus-visible{
  outline:2px solid var(--border-accent);
  outline-offset:2px;
}

footer{border-top:1px solid rgba(255,255,255,.08);padding:1rem 0;color:var(--text-secondary);font-size:.8rem}
.footer-desc{max-width:1000px;margin:.6rem auto 0;font-size:.82rem;line-height:1.5;color:var(--text-secondary);padding:0 .75rem}

/* Portal Sections */
.portal-section{
  margin-bottom:2rem;
}
@media (min-width:576px){
  .portal-section{
    margin-bottom:2.5rem;
  }
}
@media (min-width:768px){
  .portal-section{
    margin-bottom:3rem;
  }
}

.section-actions{
  margin-left:auto;
}
.section-actions .btn-more{
  font-size:.85rem;
  padding:.4rem .8rem;
  border-radius:var(--radius-sm);
}
@media (min-width:576px){
  .section-actions .btn-more{
    font-size:.9rem;
    padding:.45rem .9rem;
  }
}
@media (min-width:768px){
  .section-actions .btn-more{
    font-size:.92rem;
    padding:.5rem 1rem;
    border-radius:var(--radius);
  }
}

/* Enhanced utilities */
.fade-in{
  animation:fade-in-enhanced 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}
@keyframes fade-in-enhanced{
  0%{
    opacity:0;
    transform:translateY(12px) scale(0.98);
    filter:blur(1px);
  }
  100%{
    opacity:1;
    transform:translateY(0) scale(1);
    filter:blur(0);
  }
}

.lazy-blur{
  filter:blur(15px) brightness(0.8);
  transform:scale(1.03);
  transition:filter 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), 
             transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
             brightness 0.6s ease;
}
.lazy-blur-loaded{
  filter:blur(0) brightness(1);
  transform:scale(1);
}
/* --- Enhancements Added --- */
.featured-hero{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:linear-gradient(135deg, #1a1a1a, #0f0f0f);
  min-height:280px;
  display:flex;
  align-items:flex-end;
  padding:1.5rem 1.2rem;
  margin-bottom:1.2rem;
  isolation:isolate;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border-color);
  transition:var(--transition);
}
@media (min-width:576px){
  .featured-hero{
    min-height:320px;
    padding:1.7rem 1.5rem;
    border-radius:var(--radius-xl);
    margin-bottom:1.4rem;
  }
}
@media (min-width:768px){
  .featured-hero{
    min-height:380px;
    padding:2rem 1.8rem;
    margin-bottom:1.6rem;
  }
}
@media (min-width:992px){
  .featured-hero{
    min-height:460px;
    padding:2.8rem 2.5rem;
  }
}
.featured-hero:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 48px rgba(0,0,0,0.4);
}
.featured-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 35% 40%, 
    rgba(45,220,67,0.2) 0%, 
    rgba(33,196,182,0.15) 40%, 
    transparent 70%);
  opacity:0.6;
  mix-blend-mode:overlay;
  pointer-events:none;
}
.featured-hero-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(0.65) contrast(1.1) saturate(1.15);
  transition:var(--transition-slow);
}
.featured-hero:hover .featured-hero-img{
  transform:scale(1.05);
  filter:brightness(0.7) contrast(1.15) saturate(1.2);
}
.featured-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, 
    rgba(0,0,0,0.1) 0%, 
    rgba(0,0,0,0.4) 40%, 
    rgba(0,0,0,0.8) 100%);
}
.featured-content{
  position:relative;
  z-index:2;
  max-width:900px;
}
.featured-badge{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.35rem .8rem;
  border-radius:999px;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:0.6px;
  background:var(--gradient-primary);
  border:1px solid rgba(255,255,255,0.2);
  backdrop-filter:blur(8px);
  color:#fff;
  margin-bottom:.6rem;
  text-transform:uppercase;
  box-shadow:var(--shadow-accent);
  transition:var(--transition-fast);
}
@media (min-width:576px){
  .featured-badge{
    gap:.45rem;
    padding:.37rem .9rem;
    font-size:.72rem;
    letter-spacing:0.7px;
    margin-bottom:.7rem;
  }
}
@media (min-width:768px){
  .featured-badge{
    gap:.5rem;
    padding:.4rem 1rem;
    font-size:.75rem;
    letter-spacing:0.8px;
    margin-bottom:.8rem;
  }
}
.featured-badge:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 32px rgba(45,220,67,0.4);
}
.featured-title{
  font-size:clamp(1.3rem,4vw,2.8rem);
  font-weight:800;
  line-height:1.1;
  margin:0 0 .5rem 0;
  letter-spacing:0.5px;
  background:linear-gradient(135deg, #fff 0%, #e8fffa 50%, #d0fff0 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow:0 8px 32px rgba(0,0,0,0.6);
  filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}
@media (min-width:576px){
  .featured-title{
    font-size:clamp(1.4rem,4.2vw,2.8rem);
    margin:0 0 .55rem 0;
    letter-spacing:0.6px;
  }
}
@media (min-width:768px){
  .featured-title{
    font-size:clamp(1.5rem,4.5vw,2.8rem);
    margin:0 0 .6rem 0;
    letter-spacing:0.8px;
  }
}
.featured-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  margin:0 0 1.3rem;
  font-size:.8rem;
}
.chip{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.4rem .9rem;
  border-radius:999px;
  font-weight:600;
  background:rgba(255,255,255,0.1);
  color:#fff;
  font-size:.7rem;
  letter-spacing:0.4px;
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(6px);
  transition:var(--transition-fast);
  box-shadow:var(--shadow-sm);
}
.chip:hover{
  background:rgba(255,255,255,0.15);
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
.featured-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.9rem;
}
.btn-cta{
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.85rem 1.4rem;
  border-radius:var(--radius-lg);
  font-weight:700;
  font-size:.95rem;
  background:var(--gradient-primary);
  color:#fff;
  text-decoration:none;
  box-shadow:var(--shadow-accent), var(--shadow-md);
  transition:var(--transition);
  letter-spacing:0.3px;
  border:1px solid rgba(255,255,255,0.1);
}
.btn-cta:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, 
    rgba(255,255,255,0.3) 0%, 
    rgba(255,255,255,0.1) 50%, 
    rgba(255,255,255,0) 100%);
  opacity:0;
  transition:var(--transition);
}
.btn-cta:hover:before{
  opacity:1;
}
.btn-cta:hover{
  transform:translateY(-3px) scale(1.02);
  filter:brightness(1.1);
  box-shadow:0 12px 40px rgba(45,220,67,0.4), var(--shadow-lg);
}
.btn-secondary-outline{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.8rem 1.25rem;
  border-radius:var(--radius-lg);
  font-weight:600;
  font-size:.88rem;
  border:1px solid rgba(255,255,255,0.25);
  color:#fff;
  text-decoration:none;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(8px);
  transition:var(--transition);
  letter-spacing:0.2px;
}
.btn-secondary-outline:hover{
  background:rgba(255,255,255,0.15);
  border-color:rgba(255,255,255,0.4);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

/* Shimmer skeleton placeholder */
.shimmer{position:relative;overflow:hidden;background:linear-gradient(120deg,#1f1f1f,#252525,#1f1f1f);background-size:200% 100%;animation:shimmer 2s infinite linear}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.skeleton-thumb{width:100%;aspect-ratio:231/346;border-radius:15px}

/* Ranking medals - premium design */
.medal-1{
  background:linear-gradient(135deg, #ffd700 0%, #ffed4e 50%, #ffc107 100%)!important;
  color:#1a1a1a!important;
  box-shadow:0 6px 20px rgba(255,215,0,0.4), inset 0 1px 0 rgba(255,255,255,0.3)!important;
  border:1px solid rgba(255,255,255,0.2)!important;
}
.medal-2{
  background:linear-gradient(135deg, #e8e8e8 0%, #d4d4d4 50%, #bfbfbf 100%)!important;
  color:#1a1a1a!important;
  box-shadow:0 6px 20px rgba(192,192,192,0.3), inset 0 1px 0 rgba(255,255,255,0.4)!important;
  border:1px solid rgba(255,255,255,0.3)!important;
}
.medal-3{
  background:linear-gradient(135deg, #d2691e 0%, #cd853f 50%, #b8860b 100%)!important;
  color:#1a1a1a!important;
  box-shadow:0 6px 20px rgba(210,105,30,0.3), inset 0 1px 0 rgba(255,255,255,0.2)!important;
  border:1px solid rgba(255,255,255,0.15)!important;
}

/* Enhanced fade sequence for grid */
.stagger-fade{
  opacity:0;
  animation:stagger-enhanced 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes stagger-enhanced{
  0%{
    opacity:0;
    transform:translateY(20px) scale(0.95);
    filter:blur(2px);
  }
  60%{
    opacity:0.7;
    transform:translateY(-2px) scale(1.01);
  }
  100%{
    opacity:1;
    transform:translateY(0) scale(1);
    filter:blur(0);
  }
}

/* Utility to clamp lines */
.clamp-2{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Unified Search & Categories Section */
.unified-nav-section{
  margin-bottom:2rem;
  padding:1.5rem 1rem;
  background:var(--surface-elevated);
  border-radius:var(--radius-lg);
  border:1px solid var(--border-color);
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:visible;
  z-index:100;
}
@media (min-width:576px){
  .unified-nav-section{
    padding:1.6rem 1.2rem;
    border-radius:var(--radius-xl);
    margin-bottom:2.2rem;
  }
}
@media (min-width:768px){
  .unified-nav-section{
    padding:1.8rem 1.5rem;
    margin-bottom:2.5rem;
  }
}
.unified-nav-section:before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%, 
    rgba(45,220,67,0.05) 0%, 
    transparent 60%);
  pointer-events:none;
}
.search-categories-wrapper{
  display:flex;
  flex-direction:column;
  gap:1rem;
  align-items:center;
}
@media (min-width:576px){
  .search-categories-wrapper{
    gap:1.1rem;
  }
}
@media (min-width:768px){
  .search-categories-wrapper{
    flex-direction:column;
    align-items:center;
    gap:1.8rem;
    max-width:950px;
    margin:0 auto;
  }
}
.main-search-container{
  width:100%;
  max-width:320px;
  display:flex;
  justify-content:center;
  position:relative;
  z-index:200;
}
@media (min-width:576px){
  .main-search-container{
    max-width:420px;
  }
}
@media (min-width:768px){
  .main-search-container{
    max-width:500px;
  }
}
@media (min-width:992px){
  .main-search-container{
    max-width:600px;
  }
}
.main-search-container .portal-search{
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,0.08);
  position:relative;
  z-index:10000;
}

.search-input-wrapper{
  position:relative;
  display:flex;
  align-items:center;
}

.main-search-container .portal-search input{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.1);
  padding-right:4rem;
}

.main-search-container .portal-search input:focus{
  background:rgba(255,255,255,0.05);
  box-shadow:0 0 0 3px rgba(45,220,67,0.2), 
             0 8px 32px rgba(0,0,0,0.3);
}

.search-btn{
  position:absolute;
  right:.8rem;
  top:50%;
  transform:translateY(-50%);
  background:none;
  border:none;
  color:var(--text-secondary);
  font-size:1rem;
  cursor:pointer;
  transition:var(--transition-fast);
  padding:.3rem;
  border-radius:50%;
  z-index:3;
}

.search-btn:hover{
  color:var(--theme-color);
  background:rgba(45,220,67,0.1);
}

.search-clear{
  position:absolute;
  right:2.8rem;
  top:50%;
  transform:translateY(-50%);
  background:none;
  border:none;
  color:var(--text-muted);
  font-size:.9rem;
  cursor:pointer;
  transition:var(--transition-fast);
  padding:.2rem;
  border-radius:50%;
  z-index:3;
}

.search-clear:hover{
  color:var(--text-color);
}

.search-suggestions{
  position:absolute;
  top:100%;
  left:0;
  right:0;
  background:rgba(20,20,20,0.98);
  border:1px solid rgba(45,220,67,0.2);
  border-radius:var(--radius-lg);
  box-shadow:
    0 20px 40px rgba(0,0,0,0.5),
    0 0 0 1px rgba(45,220,67,0.1),
    inset 0 1px 0 rgba(255,255,255,0.1);
  backdrop-filter:blur(25px);
  margin-top:.3rem;
  z-index:9999;
  max-height:420px;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:thin;
  scrollbar-color:rgba(45,220,67,0.3) transparent;
}

.search-suggestions::-webkit-scrollbar{
  width:6px;
}

.search-suggestions::-webkit-scrollbar-track{
  background:transparent;
}

.search-suggestions::-webkit-scrollbar-thumb{
  background:rgba(45,220,67,0.3);
  border-radius:3px;
}

.search-suggestions::-webkit-scrollbar-thumb:hover{
  background:rgba(45,220,67,0.5);
}

.search-tips{
  background:linear-gradient(135deg,
    rgba(45,220,67,0.08) 0%,
    rgba(255,255,255,0.02) 100%);
  border-bottom:1px solid rgba(45,220,67,0.15);
  padding:.8rem 1rem;
}

.tips-header{
  display:flex;
  align-items:center;
  gap:.5rem;
  color:var(--theme-color);
  font-size:.85rem;
  font-weight:700;
  margin-bottom:.4rem;
}

.tips-content{
  display:flex;
  flex-direction:column;
  gap:.2rem;
}

.tips-content small{
  color:var(--text-muted);
  font-size:.75rem;
  font-weight:500;
}

.suggestions-header, .popular-header{
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.8rem 1rem .5rem;
  color:var(--text-muted);
  font-size:.85rem;
  font-weight:600;
  border-bottom:1px solid rgba(255,255,255,0.06);
}

.suggestions-header i, .popular-header i{
  color:var(--theme-color);
  font-size:.9rem;
}

.suggestion-items{
  max-height:150px;
  overflow-y:auto;
}

.suggestion-item{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:.6rem 1rem;
  color:var(--text-color);
  text-decoration:none;
  transition:var(--transition-fast);
  cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,0.03);
}

.suggestion-item:hover{
  background:rgba(45,220,67,0.08);
  color:var(--theme-color);
}

.suggestion-item i{
  color:var(--text-muted);
  font-size:.9rem;
}

.popular-searches{
  border-top:1px solid rgba(255,255,255,0.06);
}

.popular-items{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  padding:.5rem 1rem 1rem;
}

.popular-tag{
  padding:.3rem .8rem;
  background:rgba(45,220,67,0.1);
  color:var(--theme-color);
  border-radius:999px;
  font-size:.8rem;
  font-weight:500;
  cursor:pointer;
  transition:var(--transition-fast);
  border:1px solid rgba(45,220,67,0.2);
}

.popular-tag:hover{
  background:rgba(45,220,67,0.2);
  color:#fff;
  border-color:rgba(45,220,67,0.4);
}

.suggestion-item.selected{
  background:rgba(45,220,67,0.12);
  color:var(--theme-color);
}

/* Prevent overlapping */
.portal-section{
  position:relative;
  z-index:1;
}

.portal-section.unified-nav-section{
  z-index:100;
}

/* Search Responsive */
@media (max-width:575.98px){
  .search-suggestions{
    margin-top:.2rem;
    border-radius:var(--radius-md);
    max-height:350px;
    left:-5px;
    right:-5px;
  }
  
  .search-tips{
    padding:.6rem .8rem;
  }
  
  .tips-header{
    font-size:.8rem;
    margin-bottom:.3rem;
  }
  
  .tips-content small{
    font-size:.7rem;
  }
  
  .suggestions-header, .popular-header{
    padding:.6rem .8rem .4rem;
    font-size:.8rem;
  }
  
  .suggestion-item{
    padding:.5rem .8rem;
    font-size:.9rem;
  }
  
  .popular-items{
    padding:.4rem .8rem .8rem;
    gap:.4rem;
  }
  
  .popular-tag{
    padding:.25rem .6rem;
    font-size:.75rem;
  }
  
  .search-btn{
    right:.6rem;
    font-size:.9rem;
  }
  
  .search-clear{
    right:2.4rem;
    font-size:.85rem;
  }
}

/* Enhanced Search Animation */
.search-suggestions{
  animation:searchSlideIn 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform-origin:top center;
  will-change:transform, opacity;
}

@keyframes searchSlideIn{
  from{
    opacity:0;
    transform:translateY(-8px) scale(0.97);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

.search-suggestions.hiding{
  animation:searchSlideOut 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes searchSlideOut{
  from{
    opacity:1;
    transform:translateY(0) scale(1);
  }
  to{
    opacity:0;
    transform:translateY(-5px) scale(0.98);
  }
}

.suggestion-item, .popular-tag{
  position:relative;
  overflow:hidden;
}

.suggestion-item::before, .popular-tag::before{
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(45,220,67,0.1), transparent);
  transition:left 0.5s ease;
}

.suggestion-item:hover::before, .popular-tag:hover::before{
  left:100%;
}
.categories-filter{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:.8rem;
  width:100%;
  min-width:0;
  position:relative;
  z-index:1;
}
@media (min-width:576px){
  .categories-filter{
    justify-content:center;
    gap:.9rem;
  }
}
@media (min-width:768px){
  .categories-filter{
    gap:1rem;
  }
}
.filter-label{
  display:flex;
  align-items:center;
  gap:.4rem;
  color:var(--text-color);
  font-weight:700;
  font-size:.85rem;
  white-space:nowrap;
  margin-right:.4rem;
  padding:.4rem .6rem;
  background:rgba(255,255,255,0.03);
  border-radius:var(--radius-sm);
  border:1px solid var(--border-color);
  flex-shrink:0;
}
@media (min-width:576px){
  .filter-label{
    gap:.45rem;
    font-size:.88rem;
    margin-right:.5rem;
    padding:.42rem .65rem;
  }
}
@media (min-width:768px){
  .filter-label{
    gap:.5rem;
    font-size:.9rem;
    margin-right:.6rem;
    padding:.45rem .7rem;
    border-radius:var(--radius);
  }
}
.filter-label i{
  color:var(--theme-color);
  font-size:1rem;
}
.categories-filter .category-scroll{
  padding:.4rem 0;
  display:flex;
  justify-content:flex-start;
  flex-wrap:nowrap;
  gap:.5rem;
  max-width:100%;
  overflow-x:auto;
  scrollbar-width:none;
}
.categories-filter .category-scroll::-webkit-scrollbar{
  display:none;
}
@media (min-width:576px){
  .categories-filter .category-scroll{
    justify-content:center;
    gap:.55rem;
    padding:.45rem 0;
  }
}
@media (min-width:768px){
  .categories-filter .category-scroll{
    overflow-x:auto;
    justify-content:center;
    max-width:800px;
    gap:.6rem;
    padding:.5rem 0;
  }
}
@media (min-width:1200px){
  .categories-filter .category-scroll{
    overflow:visible;
    flex-wrap:wrap;
    max-width:900px;
  }
}
@media (max-width:767.98px){
  .categories-filter{
    flex-direction:column;
    align-items:center;
    gap:1rem;
  }
  .filter-label{
    font-size:.9rem;
    margin-right:0;
    padding:.4rem .7rem;
  }
  .categories-filter .category-scroll{
    width:100%;
    overflow-x:auto;
    justify-content:flex-start;
    flex-wrap:nowrap;
    padding:.4rem 0;
    gap:.5rem;
  }
  .unified-nav-section{
    padding:1.5rem 1rem;
    margin-bottom:2rem;
  }
}

/* Enhanced section utilities */
.gradient-bar{
  width:80px;
  height:4px;
  border-radius:999px;
  background:var(--gradient-primary);
  margin:.5rem 0 0;
  box-shadow:0 2px 8px rgba(45,220,67,0.3);
}
.section-header{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  margin-bottom:.7rem;
}
@media (min-width:576px){
  .section-header{
    gap:.65rem;
    margin-bottom:.75rem;
  }
}
@media (min-width:768px){
  .section-header{
    gap:.7rem;
    margin-bottom:.8rem;
  }
}
.section-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:999px;
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:var(--shadow-accent);
  font-size:1rem;
  transition:var(--transition-fast);
}
@media (min-width:576px){
  .section-badge{
    width:34px;
    height:34px;
    font-size:1.05rem;
  }
}
@media (min-width:768px){
  .section-badge{
    width:36px;
    height:36px;
    font-size:1.1rem;
  }
}
.section-badge:hover{
  transform:scale(1.05);
  box-shadow:0 8px 32px rgba(45,220,67,0.4);
}
.section-title{
  margin:0;
  font-weight:800;
  font-size:clamp(1rem, 2.8vw, 1.3rem);
  letter-spacing:0.3px;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
@media (min-width:576px){
  .section-title{
    letter-spacing:0.4px;
  }
}
@media (min-width:768px){
  .section-title{
    letter-spacing:0.5px;
  }
}
.section-underline{
  width:60px;
  height:3px;
  border-radius:999px;
  margin:.25rem auto 0;
  background:var(--gradient-primary);
  opacity:.9;
  box-shadow:0 2px 8px rgba(45,220,67,0.25);
}
@media (min-width:576px){
  .section-underline{
    width:66px;
    height:3.5px;
    margin:.28rem auto 0;
  }
}
@media (min-width:768px){
  .section-underline{
    width:72px;
    height:4px;
    margin:.3rem auto 0;
  }
}
