/* Featured resources page: scoped styles only. Does not modify global navigation or homepage modules. */
.featured-page .featured-main {
  min-height: 100vh;
  background:
    radial-gradient(circle at 18% 0%, rgba(40, 175, 255, 0.14), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(103, 232, 249, 0.10), transparent 30%),
    linear-gradient(180deg, rgba(4, 13, 25, 0.98), rgba(3, 10, 20, 1));
}

.featured-page .featured-hero {
  position: relative;
  min-height: clamp(420px, 48vh, 560px);
  overflow: hidden;
  border-bottom: 1px solid rgba(103, 232, 249, 0.12);
  background: #04111f;
}

.featured-page .featured-hero-bg,
.featured-page .featured-hero-mask {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.featured-page .featured-hero-bg {
  background-size: cover;
  background-position: center right;
  transform: scale(1.04);
  opacity: 0.50;
  transition: opacity 420ms ease, transform 680ms ease, background-image 420ms ease;
  filter: saturate(0.88) contrast(1.06);
}

.featured-page .featured-hero-bg.is-changing {
  opacity: 0.18;
  transform: scale(1.08);
}

.featured-page .featured-hero-mask {
  background:
    linear-gradient(90deg, rgba(3, 10, 20, 0.98) 0%, rgba(3, 10, 20, 0.88) 34%, rgba(3, 10, 20, 0.52) 62%, rgba(3, 10, 20, 0.78) 100%),
    linear-gradient(180deg, rgba(3, 10, 20, 0.20) 0%, rgba(3, 10, 20, 0.34) 62%, rgba(3, 10, 20, 0.98) 100%),
    radial-gradient(circle at 76% 24%, rgba(103, 232, 249, 0.18), transparent 36%);
}

.featured-page .featured-hero-inner {
  position: relative;
  min-height: clamp(420px, 48vh, 560px);
  display: flex;
  align-items: center;
  padding-top: 60px;
  padding-bottom: 36px;
}

.featured-page .featured-hero-copy {
  max-width: 760px;
  animation: featuredFadeUp 360ms ease both;
}

.featured-page .featured-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #66e8ff;
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.34em;
  font-weight: 800;
  margin-bottom: 22px;
  text-transform: uppercase;
}

.featured-page .featured-kicker span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #53e4ff;
  box-shadow: 0 0 18px rgba(83, 228, 255, 0.7);
}

.featured-page .featured-hero h1 {
  margin: 0;
  color: #ecf5ff;
  font-size: clamp(56px, 7.6vw, 96px);
  line-height: 0.92;
  letter-spacing: -0.08em;
  font-weight: 900;
  text-shadow: 0 28px 80px rgba(0, 0, 0, 0.36);
}

.featured-page .featured-hero p {
  max-width: 760px;
  margin: 22px 0 0;
  color: rgba(222, 235, 248, 0.78);
  font-size: clamp(16px, 1.28vw, 21px);
  line-height: 1.75;
}

.featured-page .featured-hero-tags,
.featured-page .featured-filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.featured-page .featured-hero-tags {
  margin-top: 24px;
}

.featured-page .featured-chip,
.featured-page .featured-filter-pill {
  appearance: none;
  border: 1px solid rgba(145, 180, 220, 0.24);
  color: rgba(236, 246, 255, 0.86);
  background: rgba(10, 25, 47, 0.70);
  border-radius: 999px;
  font-weight: 800;
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.featured-page .featured-chip {
  padding: 12px 18px;
  font-size: 13px;
}

.featured-page .featured-filter-pill {
  padding: 8px 12px;
  font-size: 12px;
}

.featured-page .featured-chip:hover,
.featured-page .featured-chip:focus-visible,
.featured-page .featured-filter-pill:hover,
.featured-page .featured-filter-pill:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(90, 230, 255, 0.62);
  box-shadow: 0 14px 34px rgba(34, 211, 238, 0.12);
  outline: none;
}

.featured-page .featured-chip.active,
.featured-page .featured-filter-pill.active {
  color: #04111f;
  border-color: rgba(96, 230, 255, 0.92);
  background: linear-gradient(135deg, #67e8f9 0%, #22d3ee 100%);
  box-shadow: 0 16px 36px rgba(34, 211, 238, 0.24);
}

.featured-page .featured-hero-controls {
  position: absolute;
  left: max(24px, calc((100vw - 1400px) / 2 + 24px));
  bottom: 18px;
  width: min(780px, calc(100vw - 48px));
  display: flex;
  justify-content: center;
  pointer-events: auto;
}

.featured-page .featured-hero-dots {
  display: flex;
  align-items: center;
  gap: 10px;
}

.featured-page .featured-hero-dot {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 999px;
  background: rgba(210, 228, 246, 0.36);
  cursor: pointer;
  transition: width 180ms ease, background 180ms ease, transform 180ms ease;
}

.featured-page .featured-hero-dot:hover,
.featured-page .featured-hero-dot:focus-visible {
  transform: translateY(-1px);
  outline: none;
  background: rgba(103, 232, 249, 0.78);
}

.featured-page .featured-hero-dot.active {
  width: 28px;
  background: #22e8ff;
}

.featured-page .featured-content-section {
  padding: 30px 0 84px;
}

.featured-page .featured-filter-panel {
  margin: 0 0 18px;
  padding: 12px 14px;
  border: 1px solid rgba(103, 232, 249, 0.12);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(12, 28, 51, 0.44), rgba(8, 18, 34, 0.34));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.featured-page .featured-filter-row + .featured-filter-row {
  margin-top: 7px;
}

.featured-page .featured-filter-label {
  min-width: 38px;
  color: rgba(215, 232, 248, 0.64);
  font-size: 12px;
  font-weight: 800;
}

.featured-page .featured-reco-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin: 0 0 24px;
  padding: 10px 14px;
  border: 1px solid rgba(103, 232, 249, 0.12);
  border-radius: 18px;
  background: rgba(8, 20, 38, 0.52);
  color: rgba(211, 228, 244, 0.78);
}

.featured-page .featured-reco-bar strong {
  display: block;
  color: #ecf6ff;
  font-size: 13px;
  line-height: 1.4;
}

.featured-page .featured-reco-bar span {
  display: block;
  margin-top: 4px;
  color: rgba(193, 211, 230, 0.68);
  font-size: 12px;
  line-height: 1.5;
}

.featured-page .featured-total-pill {
  flex: 0 0 auto;
  border: 1px solid rgba(103, 232, 249, 0.20);
  color: rgba(222, 238, 250, 0.86);
  background: rgba(13, 31, 55, 0.74);
  padding: 8px 13px;
  border-radius: 999px;
  font-weight: 800;
  white-space: nowrap;
}

.featured-page .featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 16px;
  transition: opacity 180ms ease, transform 180ms ease;
}

.featured-page .featured-grid.is-switching {
  opacity: 0.35;
  transform: translateY(4px);
}

.featured-page .featured-resource-card {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(103, 232, 249, 0.16);
  background: linear-gradient(180deg, rgba(9, 23, 42, 0.96), rgba(7, 18, 34, 0.96));
  cursor: pointer;
  min-height: 292px;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.18);
  transition: transform 190ms ease, border-color 190ms ease, box-shadow 190ms ease, background 190ms ease;
  animation: featuredFadeUp 260ms ease both;
}

.featured-page .featured-resource-card:hover,
.featured-page .featured-resource-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(84, 230, 255, 0.74);
  background: linear-gradient(180deg, rgba(12, 31, 56, 0.98), rgba(7, 18, 34, 0.98));
  box-shadow: 0 24px 58px rgba(0, 0, 0, 0.34), 0 0 0 1px rgba(84, 230, 255, 0.14);
  outline: none;
}

.featured-page .featured-card-cover {
  position: relative;
  height: 196px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(23, 57, 95, 0.65), rgba(6, 15, 28, 0.95));
}

.featured-page .featured-card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 300ms ease, filter 300ms ease;
}

.featured-page .featured-resource-card:hover .featured-card-cover img,
.featured-page .featured-resource-card:focus-visible .featured-card-cover img {
  transform: scale(1.028);
  filter: brightness(0.72) saturate(1.04);
}

.featured-page .featured-card-cover::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 48%;
  background: linear-gradient(180deg, transparent, rgba(5, 13, 25, 0.94));
}

.featured-page .featured-rank {
  position: absolute;
  top: 9px;
  left: 9px;
  z-index: 2;
  min-width: 32px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  background: linear-gradient(135deg, #67e8f9, #22d3ee);
  color: #03111f;
  font-size: 15px;
  font-weight: 900;
  box-shadow: 0 14px 24px rgba(10, 20, 30, 0.30);
}

.featured-page .featured-hover-cta {
  position: absolute;
  left: 50%;
  bottom: 18px;
  z-index: 3;
  transform: translate(-50%, 12px) scale(0.98);
  opacity: 0;
  padding: 8px 13px;
  border-radius: 999px;
  color: #06131f;
  background: linear-gradient(135deg, #67e8f9, #22d3ee);
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
  box-shadow: 0 18px 42px rgba(34, 211, 238, 0.22);
  transition: opacity 180ms ease, transform 180ms ease;
}

.featured-page .featured-resource-card:hover .featured-hover-cta,
.featured-page .featured-resource-card:focus-visible .featured-hover-cta {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.featured-page .featured-card-info {
  padding: 12px 12px 14px;
}

.featured-page .featured-card-title {
  color: #eef7ff;
  font-size: 15px;
  line-height: 1.35;
  font-weight: 900;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  min-height: 40px;
}

.featured-page .featured-card-meta {
  margin-top: 7px;
  color: rgba(187, 204, 225, 0.68);
  font-size: 12px;
  line-height: 1.45;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.featured-page .featured-empty {
  margin-top: 22px;
  min-height: 260px;
  border: 1px solid rgba(103, 232, 249, 0.14);
  border-radius: 18px;
  background: rgba(10, 25, 47, 0.74);
  display: grid;
  place-content: center;
  text-align: center;
  gap: 12px;
  color: rgba(218, 233, 247, 0.78);
}

.featured-page .featured-empty[hidden] { display: none; }
.featured-page .featured-empty strong { color: #edf7ff; font-size: 24px; }
.featured-page .featured-empty div { display: flex; justify-content: center; gap: 12px; margin-top: 7px; }

.featured-page .featured-load-more-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 34px;
}

.featured-page .featured-load-note {
  color: rgba(190, 209, 229, 0.58);
  font-size: 13px;
  line-height: 1.4;
}

.featured-page .featured-load-more[hidden] {
  display: none;
}

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

@media (max-width: 1280px) {
  .featured-page .featured-grid { grid-template-columns: repeat(auto-fill, minmax(132px, 1fr)); }
  .featured-page .featured-card-cover { height: 188px; }
  .featured-page .featured-resource-card { min-height: 282px; }
}

@media (max-width: 980px) {
  .featured-page .featured-hero, .featured-page .featured-hero-inner { min-height: 430px; }
  .featured-page .featured-reco-bar { align-items: flex-start; flex-direction: column; }
  .featured-page .featured-total-pill { align-self: flex-start; }
}

@media (max-width: 640px) {
  .featured-page .featured-hero, .featured-page .featured-hero-inner { min-height: 410px; }
  .featured-page .featured-hero-inner { padding-top: 92px; }
  .featured-page .featured-hero h1 { font-size: 58px; }
  .featured-page .featured-hero-controls { left: 18px; right: 18px; width: auto; }
  .featured-page .featured-content-section { padding-top: 28px; }
  .featured-page .featured-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
  .featured-page .featured-card-cover { height: 220px; }
  .featured-page .featured-resource-card { min-height: 326px; border-radius: 18px; }
  .featured-page .featured-card-info { padding: 12px 12px 14px; }
  .featured-page .featured-card-title { font-size: 16px; min-height: 44px; }
}


/* v2 polish: make featured page lighter and let cards be the visual focus. */
.featured-page .featured-hero,
.featured-page .featured-hero-inner {
  min-height: clamp(420px, 48vh, 560px);
}

.featured-page .featured-content-section {
  padding-top: 30px;
}

.featured-page .featured-filter-panel {
  padding: 12px 14px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(12, 28, 51, 0.44), rgba(8, 18, 34, 0.34));
}

.featured-page .featured-reco-bar {
  padding: 10px 14px;
  border-radius: 18px;
  background: rgba(8, 20, 38, 0.42);
}

.featured-page .featured-grid {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 16px;
}

.featured-page .featured-resource-card {
  min-height: 292px;
  border-radius: 18px;
}

.featured-page .featured-card-cover {
  height: 196px;
}

.featured-page .featured-resource-card:hover .featured-card-cover img,
.featured-page .featured-resource-card:focus-visible .featured-card-cover img {
  transform: scale(1.028);
}

.featured-page .featured-rank {
  min-width: 32px;
  height: 30px;
  font-size: 15px;
}

.featured-page .featured-hover-cta {
  bottom: 18px;
  padding: 8px 13px;
  font-size: 13px;
}

.featured-page .featured-card-title {
  font-size: 15px;
  min-height: 40px;
}

.featured-page .featured-card-meta {
  font-size: 12px;
}

.featured-page .featured-load-more-wrap {
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.featured-page .featured-load-note {
  color: rgba(190, 209, 229, 0.58);
  font-size: 13px;
  line-height: 1.4;
}

@media (max-width: 1280px) {
  .featured-page .featured-grid { grid-template-columns: repeat(auto-fill, minmax(132px, 1fr)); }
  .featured-page .featured-card-cover { height: 188px; }
  .featured-page .featured-resource-card { min-height: 282px; }
}

@media (max-width: 980px) {
  .featured-page .featured-hero,
  .featured-page .featured-hero-inner { min-height: 430px; }
}

@media (max-width: 640px) {
  .featured-page .featured-hero,
  .featured-page .featured-hero-inner { min-height: 410px; }
  .featured-page .featured-card-cover { height: 220px; }
  .featured-page .featured-resource-card { min-height: 326px; }
}

/* recommend.html intentionally reuses featured-page class names for pixel-level consistency. */

/* Step 4 component standardization - featured/list page local overrides */
.featured-page .featured-filter-pill,
.featured-page .featured-chip{
  min-height:38px;
  border-radius:999px;
  border-color:rgba(118,180,255,.18);
  background:rgba(255,255,255,.055);
  transition:transform .2s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease,color .2s ease;
}
.featured-page .featured-filter-pill:hover,
.featured-page .featured-chip:hover{
  transform:translateY(-2px);
  border-color:rgba(72,200,255,.42);
  background:rgba(72,200,255,.10);
}
.featured-page .featured-filter-pill.active,
.featured-page .featured-chip.active{
  border-color:rgba(72,200,255,.62);
  box-shadow:0 12px 28px rgba(72,200,255,.16);
}
.featured-page .featured-filter-pill:focus-visible,
.featured-page .featured-chip:focus-visible,
.featured-page .featured-resource-card:focus-visible{
  outline:2px solid rgba(72,200,255,.88);
  outline-offset:3px;
  box-shadow:0 0 0 4px rgba(72,200,255,.14);
}
.featured-page .featured-resource-card{
  border-color:rgba(118,180,255,.18);
  box-shadow:0 10px 34px rgba(0,0,0,.22);
}
.featured-page .featured-resource-card:hover,
.featured-page .featured-resource-card:focus-visible{
  border-color:rgba(72,200,255,.42);
}
.featured-page .featured-card-cover img{
  background:linear-gradient(135deg,rgba(72,200,255,.10),rgba(124,108,255,.10)),#0b1628;
}
.featured-page .featured-empty{
  border-color:rgba(118,180,255,.18);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(13,25,45,.72),rgba(9,18,34,.64));
  box-shadow:0 10px 34px rgba(0,0,0,.22);
}
