/* S2: Zoekbalk */
#receptZoekInput:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(90,179,53,.12);
}
#receptZoekInput::placeholder { color:var(--dim); }
.rc-wrap {
  position:relative;overflow:hidden;border-radius:var(--r-xl);
  touch-action:pan-y;
}
.rc-track {
  display:flex;
  transition:transform .38s cubic-bezier(.16,1,.3,1);
  will-change:transform;
}
.rc-kaart {
  flex:0 0 100%;width:100%;
  background:var(--panel);border:1px solid var(--border2);
  border-radius:var(--r-xl);overflow:hidden;
  box-sizing:border-box;
}
.rc-header {
  padding:1.4rem 1.4rem .9rem;
  background:linear-gradient(135deg,rgba(82,184,46,.07),rgba(82,184,46,.02));
  border-bottom:1px solid var(--border);
}
.rc-compleet .rc-header {
  background:linear-gradient(135deg,rgba(82,184,46,.12),rgba(82,184,46,.04));
}
.rc-emoji { font-size:2.8rem;margin-bottom:.6rem;display:block;line-height:1; }
/* S3: cover foto of gradient-fallback */
.rc-cover {
  width:100%;height:160px;border-radius:12px;overflow:hidden;
  margin-bottom:.9rem;position:relative;
}
.rc-cover img {
  width:100%;height:100%;object-fit:cover;display:block;
}
.rc-cover-fallback {
  background:linear-gradient(135deg,#2d6a1f,#5ab52d,#f5a623);
  display:flex;align-items:center;justify-content:center;
}
.rc-cover-emoji {
  font-size:3.8rem;line-height:1;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.25));
}
.rc-naam {
  font-family:var(--font-display);font-size:1.3rem;font-weight:800;
  color:var(--text);letter-spacing:-.03em;line-height:1.2;margin:0 0 .4rem;
}
.rc-beschrijving { font-size:.84rem;color:var(--sub);line-height:1.6;margin:0; }
.rc-chips {
  display:flex;flex-wrap:wrap;gap:.35rem;
  padding:.8rem 1.4rem;border-bottom:1px solid var(--border);
}
.rc-chip {
  font-size:.71rem;padding:.2rem .55rem;border-radius:7px;
  background:var(--bg2);color:var(--sub);border:1px solid var(--border);
}
.rc-chip-groen { background:rgba(82,184,46,.08);color:var(--accent);border-color:rgba(82,184,46,.18); }
.rc-chip-oranje { background:rgba(224,125,24,.08);color:var(--warm);border-color:rgba(224,125,24,.18); }
.rc-chip-kcal   { background:rgba(255,140,80,.1);color:#ff8c50;border-color:rgba(255,140,80,.25);font-weight:700; }
.rc-macros {
  display:flex;gap:.5rem;padding:.55rem 1.4rem .65rem;
  border-bottom:1px solid var(--border);flex-wrap:wrap;
}
.rc-macro {
  display:flex;flex-direction:column;align-items:center;
  min-width:52px;flex:1;padding:.35rem .4rem;border-radius:10px;border:1px solid transparent;
}
.rc-macro-val  { font-size:.82rem;font-weight:800;line-height:1; }
.rc-macro-lbl  { font-size:.58rem;color:var(--sub);margin-top:.15rem;text-transform:uppercase;letter-spacing:.04em; }
.rc-macro-eiwit  { background:rgba(91,155,213,.07);border-color:rgba(91,155,213,.18); }
.rc-macro-eiwit .rc-macro-val  { color:var(--blue); }
.rc-macro-kh     { background:rgba(90,179,53,.07);border-color:rgba(90,179,53,.18); }
.rc-macro-kh .rc-macro-val     { color:var(--accent); }
.rc-macro-vet    { background:rgba(232,132,26,.07);border-color:rgba(232,132,26,.18); }
.rc-macro-vet .rc-macro-val    { color:var(--warm); }
.rc-macro-vezels { background:var(--bg2);border-color:var(--border2); }
.rc-macro-vezels .rc-macro-val { color:var(--sub); }
.dieet-filter {
  font-size:.72rem;padding:.28rem .7rem;border-radius:20px;
  background:var(--bg2);color:var(--sub);border:1.5px solid var(--border2);
  font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap;
}
.dieet-filter:hover { border-color:var(--accent);color:var(--accent); }
.dieet-filter.actief { background:rgba(82,184,46,.12);color:var(--accent);border-color:rgba(82,184,46,.4);font-weight:700; }
.rc-ing {
  padding:.9rem 1.4rem;border-bottom:1px solid var(--border);
}
.rc-ing-titel {
  font-size:.67rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--dim);margin-bottom:.55rem;
}
.rc-ing-lijst { display:flex;flex-wrap:wrap;gap:.3rem; }
.rc-personen-slider {
  display:flex;align-items:center;gap:.8rem;
  padding:.55rem 1.4rem;border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.rc-ps-btn {
  width:2rem;height:2rem;border-radius:50%;
  border:1.5px solid var(--border);background:var(--card);
  color:var(--text);font-size:1.1rem;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s,border-color .15s;line-height:1;
}
.rc-ps-btn:hover { background:var(--accent);color:#fff;border-color:var(--accent); }
.rc-ps-label {
  flex:1;text-align:center;font-size:.85rem;font-weight:700;color:var(--text);
}
.rc-acties {
  display:flex;gap:.6rem;padding:1rem 1.4rem 1.3rem;flex-wrap:wrap;
}
.rc-btn-kies {
  flex:1;padding:.8rem 1rem;border-radius:12px;border:none;
  background:linear-gradient(135deg,var(--accent),#3db87a);
  color:#fff;font-size:.9rem;font-weight:800;
  font-family:var(--font);cursor:pointer;
  box-shadow:0 4px 16px rgba(82,184,46,.25);
  transition:transform .15s,box-shadow .15s;
}
.rc-btn-kies:hover { transform:translateY(-1px);box-shadow:0 6px 20px rgba(82,184,46,.35); }
.rc-btn-fav {
  padding:.8rem .9rem;border-radius:12px;border:1px solid var(--border2);
  background:transparent;color:var(--sub);font-size:1rem;cursor:pointer;
  transition:border-color .15s,color .15s;
}
.rc-btn-fav.actief { border-color:rgba(232,132,26,.4);color:var(--warm); }
.rc-btn-mis {
  width:100%;padding:.7rem 1rem;border-radius:12px;
  border:1px solid rgba(224,125,24,.3);background:rgba(224,125,24,.06);
  color:var(--warm);font-size:.8rem;font-weight:700;
  font-family:var(--font);cursor:pointer;
}
/* Navigatie pijlen + teller */
.rc-nav {
  display:flex;align-items:center;justify-content:center;gap:1rem;
  padding:.8rem 0 .2rem;
}
.rc-nav-btn {
  width:36px;height:36px;border-radius:50%;
  background:var(--panel);border:1px solid var(--border2);
  color:var(--sub);font-size:.9rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.rc-nav-btn:hover { border-color:var(--accent);color:var(--accent); }
.rc-nav-btn:disabled { opacity:.25;cursor:default; }
.rc-nav-teller {
  font-size:.82rem;font-weight:700;color:var(--text);
  min-width:60px;text-align:center;
}
/* Swipe hint */
.rc-swipe-hint {
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.rc-swipe-hint-l { left:12px; }
.rc-swipe-hint-r { right:12px; }
