
.rcard {
  background: #fff;
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-sm);
  border: 1px solid rgba(212,85,10,.06);
  cursor: pointer;
  transition: transform var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              border-color var(--t-base);
  position: relative;
}
.rcard:hover {
  transform: translateY(-7px);
  box-shadow: var(--sh-lg);
  border-color: rgba(212,85,10,.14);
}

.rcard-img-wrap { position: relative; height: 210px; overflow: hidden; }
.rcard-img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s var(--ease-out);
}
.rcard:hover .rcard-img-wrap img { transform: scale(1.07); }
.rcard-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(24,14,7,.45) 0%, transparent 55%);
}

.rcard-badges {
  position: absolute; top: var(--sp-3); left: var(--sp-3); right: var(--sp-3);
  display: flex; justify-content: space-between; align-items: flex-start;
}
.rcard-diff-tag {
  font-family: var(--font-body);
  font-size: var(--fs-xs); font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: .28rem .7rem; border-radius: var(--r-full);
  backdrop-filter: blur(8px);
}
.rcard-diff-easy   { background: rgba(21,128,61,.18);  color: #DCFCE7; border: 1px solid rgba(21,128,61,.3); }
.rcard-diff-medium { background: rgba(194,65,12,.2);   color: #FFEDD5; border: 1px solid rgba(194,65,12,.3); }
.rcard-diff-hard   { background: rgba(185,28,28,.2);   color: #FEE2E2; border: 1px solid rgba(185,28,28,.3); }

.fav-btn {
  width: 32px; height: 32px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.28);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--t-base) var(--ease-spring);
  backdrop-filter: blur(8px);
}
.fav-btn:hover { background: var(--c-orange); border-color: var(--c-orange); transform: scale(1.12); }
.fav-btn.on { background: var(--c-orange); border-color: var(--c-orange); }
.fav-btn svg { width: 14px; height: 14px; stroke: #fff; fill: none; transition: fill var(--t-fast); }
.fav-btn.on svg { fill: #fff; }

.rcard-body { padding: var(--sp-5) var(--sp-5) var(--sp-5); }
.rcard-cats { display: flex; flex-wrap: wrap; gap: var(--sp-1); margin-bottom: var(--sp-3); }
.rcard-cat-pill {
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  padding: .18rem .6rem; border-radius: var(--r-full);
  background: var(--c-orange-pale2); color: var(--c-orange);
  border: 1px solid rgba(212,85,10,.14);
}
.rcard-title {
  font-family: var(--font-display);
  font-size: 1.15rem; font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  color: var(--c-ink);
  margin-bottom: var(--sp-2);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.rcard-desc {
  font-size: var(--fs-sm); font-weight: var(--fw-light);
  color: var(--c-ink-3); line-height: var(--lh-normal);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  margin-bottom: var(--sp-4);
}

.rcard-footer {
  display: flex; align-items: center; gap: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--c-cream-3);
}
.rcard-meta {
  display: flex; align-items: center; gap: var(--sp-1);
  font-size: var(--fs-xs); font-weight: var(--fw-medium); color: var(--c-ink-4);
}
.rcard-meta svg { width: 12px; height: 12px; color: var(--c-orange); }

.rcard-featured .rcard-img-wrap { height: 310px; }
.rcard-featured .rcard-title {
  font-size: clamp(1.25rem, 2.5vw, 1.7rem);
  -webkit-line-clamp: 3;
}

.rcard-sm {
  background: #fff;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-sm);
  border: 1px solid rgba(212,85,10,.06);
  cursor: pointer;
  display: flex; gap: var(--sp-4);
  padding: var(--sp-4);
  transition: all var(--t-base) var(--ease-out);
}
.rcard-sm:hover { transform: translateX(5px); box-shadow: var(--sh-md); border-color: rgba(212,85,10,.14); }
.rcard-sm-img { width: 88px; height: 88px; border-radius: var(--r-md); object-fit: cover; flex-shrink: 0; }
.rcard-sm-body { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.rcard-sm-title {
  font-family: var(--font-display);
  font-size: var(--fs-md); font-weight: var(--fw-bold);
  line-height: var(--lh-snug); color: var(--c-ink);
  margin-bottom: var(--sp-2);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.rcard-sm-meta { display: flex; gap: var(--sp-4); flex-wrap: wrap; }
.rcard-sm-meta span {
  display: flex; align-items: center; gap: var(--sp-1);
  font-size: var(--fs-xs); font-weight: var(--fw-medium); color: var(--c-ink-4);
}
.rcard-sm-meta svg { width: 11px; height: 11px; color: var(--c-orange); }

.ccard {
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  cursor: pointer;
  border: 1.5px solid transparent;
  position: relative; overflow: hidden;
  transition: transform var(--t-base) var(--ease-out),
              box-shadow var(--t-base),
              border-color var(--t-base);
}
.ccard:hover { transform: translateY(-5px); box-shadow: var(--sh-md); }
.ccard.cc-1 { background: var(--cc-1-bg); }
.ccard.cc-2 { background: var(--cc-2-bg); }
.ccard.cc-3 { background: var(--cc-3-bg); }
.ccard.cc-4 { background: var(--cc-4-bg); }
.ccard.cc-5 { background: var(--cc-5-bg); }
.ccard.cc-6 { background: var(--cc-6-bg); }
.ccard.cc-7 { background: var(--cc-7-bg); }
.ccard.cc-8 { background: var(--cc-8-bg); }
.ccard.cc-9 { background: var(--cc-9-bg); }
.ccard:hover { border-color: rgba(212,85,10,.25); }

.ccard-icon {
  font-size: 2.1rem; display: block; margin-bottom: var(--sp-4);
  transition: transform var(--t-base) var(--ease-spring);
}
.ccard:hover .ccard-icon { transform: scale(1.18) rotate(-5deg); }
.ccard-name {
  font-family: var(--font-display);
  font-size: var(--fs-md); font-weight: var(--fw-bold);
  color: var(--c-ink); margin-bottom: var(--sp-2);
}
.ccard-desc {
  font-size: var(--fs-xs); font-weight: var(--fw-light);
  color: var(--c-ink-3); line-height: var(--lh-normal); margin-bottom: var(--sp-4);
}
.ccard-footer { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--sp-2); }
.ccard-count {
  font-size: var(--fs-xs); font-weight: var(--fw-bold);
  background: rgba(212,85,10,.12); color: var(--c-orange);
  padding: .2rem .65rem; border-radius: var(--r-full);
}
.ccard-avgtime { font-size: var(--fs-xs); font-weight: var(--fw-light); color: var(--c-ink-4); margin-top: var(--sp-2); }

.stat-card {
  background: #fff; border-radius: var(--r-xl); padding: var(--sp-6);
  box-shadow: var(--sh-sm); border: 1px solid rgba(212,85,10,.06);
  transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.stat-label {
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--fs-xs); font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider); text-transform: uppercase;
  color: var(--c-ink-4); margin-bottom: var(--sp-3);
}
.stat-icon {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: var(--c-orange-pale); display: flex; align-items: center; justify-content: center;
}
.stat-icon svg { width: 16px; height: 16px; color: var(--c-orange); }
.stat-val {
  font-family: var(--font-display); font-size: var(--fs-3xl);
  font-weight: var(--fw-bold); color: var(--c-ink); line-height: 1;
}
.stat-sub { font-size: var(--fs-xs); font-weight: var(--fw-light); color: var(--c-ink-4); margin-top: var(--sp-2); }
