/* ================================================================
   RECETTE DETAIL — Dark Glass Premium
   ================================================================ */
:root {
  --rd-bg:      #030f07;
  --rd-card:    rgba(12,30,18,0.97);
  --rd-cb:      rgba(52,211,153,0.1);
  --rd-cbh:     rgba(52,211,153,0.28);
  --rd-em:      #34d399;
  --rd-em-d:    rgba(52,211,153,0.1);
  --rd-em-m:    rgba(52,211,153,0.18);
  --rd-amber:   #fbbf24;
  --rd-amber-d: rgba(245,158,11,0.1);
  --rd-w100: #fff;
  --rd-w75:  rgba(255,255,255,0.75);
  --rd-w55:  rgba(255,255,255,0.55);
  --rd-w30:  rgba(255,255,255,0.3);
  --rd-w12:  rgba(255,255,255,0.12);
  --rd-w06:  rgba(255,255,255,0.06);
}

.rd-page { background: var(--rd-bg); color: var(--rd-w100); font-family: 'DM Sans', sans-serif; }
.rd-page *, .rd-page *::before, .rd-page *::after { box-sizing: border-box; }

/* ── TOASTS ──────────────────────────────── */
#toast-container {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  z-index: 9999; pointer-events: none;
}
.hp-toast {
  background: rgba(3,20,12,0.95); backdrop-filter: blur(24px);
  border: 1px solid rgba(52,211,153,0.3); border-radius: 999px;
  padding: 12px 24px; display: flex; align-items: center; gap: 12px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  pointer-events: auto; position: relative; overflow: hidden;
  animation: toastSlideUp .5s cubic-bezier(.34,1.4,.64,1) forwards;
  opacity: 0; transform: translateY(20px);
}
.hp-toast.toast-error { border-color: rgba(239,68,68,0.4); }
.hp-toast-icon { font-size: 18px; flex-shrink: 0; }
.hp-toast-msg { font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 600; color: #fff; margin: 0; padding-right: 8px; }
.hp-toast-progress { position: absolute; bottom: 0; left: 0; height: 3px; background: #34d399; width: 100%; animation: toastProgress 4s linear forwards; }
.hp-toast.toast-error .hp-toast-progress { background: #ef4444; }
.hp-toast.toast-fade-out { animation: toastFadeOut .4s ease-in forwards; }
@keyframes toastSlideUp { to { opacity: 1; transform: translateY(0); } }
@keyframes toastProgress { from { width: 100%; } to { width: 0%; } }
@keyframes toastFadeOut { to { opacity: 0; transform: translateY(20px); } }

/* ── BARRE MODÉRATION ────────────────────── */
.rd-mod-wrapper {
  position: sticky;
  top: 72px;
  z-index: 50;
  max-width: 1100px;
  margin: 0 auto;
  padding: 10px 32px 0;
  pointer-events: none;
}
.rd-mod-bar {
  pointer-events: auto;
  background: rgba(20,12,3,0.88);
  backdrop-filter: blur(22px) saturate(180%);
  -webkit-backdrop-filter: blur(22px) saturate(180%);
  border: 1px solid rgba(254,215,60,0.30);
  border-radius: 20px;
  padding: 13px 18px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; flex-wrap: wrap;
  box-shadow:
    0 8px 32px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 0 0 1px rgba(254,215,60,.04);
}
.rd-mod-info { display: flex; align-items: center; gap: 10px; }
.rd-mod-dot {
  width: 8px; height: 8px;
  background: #fbbf24; border-radius: 50%; flex-shrink: 0;
  animation: rdModPulse 2s ease-in-out infinite;
}
@keyframes rdModPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(251,191,36,.6); }
  50%     { box-shadow: 0 0 0 7px rgba(251,191,36,0); }
}
.rd-mod-label {
  font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700;
  color: rgba(254,240,138,.92); letter-spacing: .15px;
}
.rd-mod-sublabel {
  font-family: 'Poppins',sans-serif; font-size: 10px; font-weight: 500;
  color: rgba(254,240,138,.42); margin-top: 1px;
}
.rd-mod-btns { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.rd-mod-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 22px; border-radius: 13px;
  font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 800;
  border: none; cursor: pointer;
  transition: all .22s cubic-bezier(.34,1.4,.64,1);
  position: relative; overflow: hidden; letter-spacing: .15px;
}
.rd-mod-btn::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 35%, rgba(255,255,255,.18) 50%, transparent 65%);
  transform: translateX(-100%); transition: transform .45s ease;
}
.rd-mod-btn:hover::after { transform: translateX(100%); }
.rd-mod-btn.ok {
  background: linear-gradient(135deg, #059669, #10b981);
  color: #fff; box-shadow: 0 4px 18px rgba(16,185,129,.38);
}
.rd-mod-btn.ok:hover {
  background: linear-gradient(135deg, #047857, #059669);
  transform: translateY(-2px); box-shadow: 0 8px 28px rgba(16,185,129,.48);
}
.rd-mod-btn.ok:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(16,185,129,.3); }
.rd-mod-btn.ko {
  background: linear-gradient(135deg, #dc2626, #ef4444);
  color: #fff; box-shadow: 0 4px 18px rgba(239,68,68,.38);
}
.rd-mod-btn.ko:hover {
  background: linear-gradient(135deg, #b91c1c, #dc2626);
  transform: translateY(-2px); box-shadow: 0 8px 28px rgba(239,68,68,.48);
}
.rd-mod-btn.ko:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(239,68,68,.3); }

/* light mode modération */
[data-theme="light"] .rd-mod-bar {
  background: rgba(255,253,235,.95);
  border-color: rgba(217,119,6,.32);
  box-shadow: 0 6px 24px rgba(0,0,0,.10), inset 0 0 0 1px rgba(217,119,6,.06);
}
[data-theme="light"] .rd-mod-dot      { background: #d97706; }
[data-theme="light"] .rd-mod-label    { color: rgba(120,53,15,.92); }
[data-theme="light"] .rd-mod-sublabel { color: rgba(120,53,15,.48); }

@media (max-width: 767px) {
  .rd-mod-wrapper { top: 58px; padding: 8px 12px 0; }
  .rd-mod-bar     { padding: 10px 13px; border-radius: 15px; gap: 10px; }
  .rd-mod-btn     { padding: 9px 15px; font-size: 11px; border-radius: 11px; }
}

/* ── HERO ─────────────────────────────────── */
.rd-hero {
  position: relative; height: 82vh; min-height: 520px; max-height: 820px;
  overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end;
}
.rd-hero-img { position: absolute; inset: 0; object-fit: cover; width: 100%; height: 100%; animation: rdZoom 26s ease-in-out infinite alternate; }
.rd-hero-empty { position: absolute; inset: 0; background: linear-gradient(135deg,rgba(12,40,24,.8),rgba(3,15,7,.9)); display: flex; align-items: center; justify-content: center; font-size: 96px; opacity: .2; }
@keyframes rdZoom { from{transform:scale(1.04);} to{transform:scale(1.12);} }
.rd-hero-ov { position: absolute; inset: 0; background: linear-gradient(to top,#030f07 0%,rgba(3,15,7,.88) 28%,rgba(3,15,7,.22) 62%,rgba(3,15,7,.55) 100%); }
.rd-hero-glow { position: absolute; bottom: -80px; left: -100px; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle,rgba(52,211,153,.1) 0%,transparent 65%); pointer-events: none; }
.rd-hero-grain { position: absolute; inset: 0; opacity: .025; pointer-events: none; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size: 220px; }

.rd-pop-badge {
  position: absolute; top: 28px; right: 32px; z-index: 5;
  backdrop-filter: blur(14px); border-radius: 14px; padding: 9px 18px;
  font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 800; color: #fff;
  display: inline-flex; align-items: center; gap: 6px;
}
.rd-pop-badge.vogue { background: rgba(239,68,68,.82); border: 1px solid rgba(252,165,165,.2); animation: rdPopPulse 2.2s ease-in-out infinite; }
.rd-pop-badge.pop   { background: rgba(249,115,22,.82); border: 1px solid rgba(253,186,116,.2); }
@keyframes rdPopPulse { 0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5);}50%{box-shadow:0 0 0 9px rgba(239,68,68,0);} }

.rd-hero-content { position: relative; z-index: 2; max-width: 1100px; margin: 0 auto; width: 100%; padding: 0 32px 60px; }
.rd-breadcrumb { display: flex; align-items: center; gap: 7px; margin-bottom: 18px; font-family: 'Poppins',sans-serif; font-size: 9px; font-weight: 700; color: var(--rd-w30); text-transform: uppercase; letter-spacing: 2.5px; }
.rd-breadcrumb a { color: var(--rd-w30); text-decoration: none; transition: color .2s; }
.rd-breadcrumb a:hover { color: var(--rd-em); }
.rd-breadcrumb span { color: rgba(255,255,255,.15); }
.rd-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.rd-tag { display: inline-flex; align-items: center; gap: 5px; padding: 5px 13px; border-radius: 10px; background: rgba(6,22,14,.75); backdrop-filter: blur(14px); border: 1px solid rgba(52,211,153,.25); font-family: 'Poppins',sans-serif; font-size: 9px; font-weight: 700; color: var(--rd-em); text-transform: uppercase; letter-spacing: 1.8px; }

/* ── TITRE (STYLE CINEMA) ────────────────── */
.rd-title { 
  font-family: 'Playfair Display', serif; 
  font-size: clamp(38px,6.5vw,82px); 
  font-weight: 700; 
  color: #fff; 
  line-height: 1.05; 
  letter-spacing: -1px; 
  text-shadow: 0 4px 32px rgba(0,0,0,.55); 
  margin-bottom: 24px; 
}

.rd-title em {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 400;
  display: block; /* CRUCIAL : Force la ligne 2 */
  width: 100%;
  margin-top: 4px;
  color: inherit;
}

/* ── DESCRIPTION AVEC FOND TRANSPARENT ── */
.rd-desc-hero {
  font-family: 'DM Sans',sans-serif;
  font-size: 17px;
  font-style: italic;
  color: #fff;
  border-left: 2px solid rgba(52,211,153,.38);
  padding: 16px 20px;
  max-width: 600px;
  line-height: 1.75;
  margin-bottom: 28px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 0 12px 12px 0;
}

.rd-hero-btns { display: flex; gap: 10px; align-items: center; }
.rd-hero-btn { width: 50px; height: 50px; border-radius: 16px; display: flex; align-items: center; justify-content: center; background: rgba(6,22,14,.78); backdrop-filter: blur(16px); border: 1px solid var(--rd-w12); font-size: 22px; cursor: pointer; transition: all .25s; text-decoration: none; }
.rd-hero-btn:hover { border-color: rgba(52,211,153,.35); background: rgba(52,211,153,.1); }

/* ── AUTEUR ───────────────────────────────── */
.rd-author-zone { max-width: 1100px; margin: -30px auto 0; padding: 0 32px; position: relative; z-index: 20; }
.rd-author-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.rd-author-card { display: inline-flex; align-items: center; gap: 14px; background: var(--rd-card); backdrop-filter: blur(28px); border: 1px solid var(--rd-cb); border-radius: 22px; padding: 12px 22px 12px 12px; box-shadow: 0 20px 56px rgba(0,0,0,.5); }
.rd-author-av { width: 50px; height: 50px; border-radius: 15px; overflow: hidden; border: 2px solid rgba(52,211,153,.28); flex-shrink: 0; }
.rd-author-av img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rd-author-name { font-family: 'Poppins',sans-serif; font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 2px; }
.rd-author-grade { font-family: 'Poppins',sans-serif; font-size: 9px; font-weight: 700; color: var(--rd-em); text-transform: uppercase; letter-spacing: 1.2px; }
.rd-author-date { font-size: 10px; color: var(--rd-w30); margin-top: 3px; }
.rd-rating-chip { display: inline-flex; align-items: center; gap: 12px; background: var(--rd-card); backdrop-filter: blur(28px); border: 1px solid rgba(245,158,11,.18); border-radius: 22px; padding: 12px 20px; text-decoration: none; box-shadow: 0 20px 56px rgba(0,0,0,.5); transition: border-color .2s; }
.rd-rating-chip:hover { border-color: rgba(245,158,11,.3); }
.rd-rating-num { font-family: 'Poppins',sans-serif; font-size: 28px; font-weight: 900; color: var(--rd-amber); }
.rd-rating-div { width: 1px; height: 36px; background: var(--rd-w12); }
.rd-rating-lbl { font-size: 9px; font-weight: 700; color: var(--rd-w30); text-transform: uppercase; letter-spacing: 1px; display: block; margin-bottom: 2px; }
.rd-rating-count { font-family: 'Poppins',sans-serif; font-size: 20px; font-weight: 900; color: var(--rd-w100); }
.rd-edit-btns { display: flex; gap: 8px; }
.rd-edit-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 18px; border-radius: 14px; cursor: pointer; font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 700; transition: all .2s; text-decoration: none; }
.rd-edit-btn.blue { background: rgba(59,130,246,.1); border: 1px solid rgba(59,130,246,.22); color: #93c5fd; }
.rd-edit-btn.blue:hover { background: rgba(59,130,246,.18); }
.rd-edit-btn.red  { background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.18); color: #fca5a5; }
.rd-edit-btn.red:hover { background: rgba(239,68,68,.15); }

/* ── MAIN WRAP ───────────────────────────── */
.rd-wrap { max-width: 1100px; margin: 0 auto; padding: 32px 32px 96px; }
.rd-glass-line { height: 1px; background: linear-gradient(to right,transparent,rgba(52,211,153,.16),transparent); margin: 36px 0; }
.rd-sh { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.rd-sh-icon { width: 42px; height: 42px; border-radius: 14px; background: var(--rd-em-d); border: 1px solid var(--rd-em-m); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.rd-sh-title { font-family: 'Poppins',sans-serif; font-size: 28px; font-weight: 900; color: #fff; }

/* ── PLANNING ─────────────────────────────── */
.rd-planning {
  background: linear-gradient(135deg,rgba(30,27,75,.98),rgba(49,46,129,.96));
  border: 1px solid rgba(129,140,248,.2); border-radius: 22px;
  padding: 3px; margin-bottom: 28px;
  display: flex; align-items: center;
  box-shadow: 0 16px 48px rgba(79,70,229,.18); overflow: hidden;
}
.rd-planning-lbl { display: flex; align-items: center; gap: 12px; padding: 10px 18px; flex-shrink: 0; }
.rd-planning-ico { width: 40px; height: 40px; background: rgba(255,255,255,.1); border-radius: 13px; display: flex; align-items: center; justify-content: center; font-size: 20px; border: 1px solid rgba(255,255,255,.15); }
.rd-planning-title { font-family: 'Poppins',sans-serif; font-size: 14px; font-weight: 800; color: #fff; }
.rd-planning-sub { font-size: 9px; color: rgba(199,210,254,.85); font-weight: 600; }
.rd-planning-form { flex: 1; background: rgba(255,255,255,.96); border-radius: 18px; padding: 4px; display: flex; align-items: center; gap: 4px; margin: 3px; }
.rd-pf-field { flex: 1; padding: 7px 14px; border-radius: 13px; cursor: pointer; transition: background .2s; }
.rd-pf-field:hover { background: rgba(99,102,241,.06); }
.rd-pf-label { display: block; font-size: 7px; font-weight: 900; color: #6366f1; text-transform: uppercase; letter-spacing: .15em; margin-bottom: 1px; }
.custom-input-wrapper select, .custom-input-wrapper input { width: 100%; border: none !important; background: transparent !important; padding: 0 !important; font-weight: 900; color: #312e81; outline: none !important; cursor: pointer; font-size: 1rem; box-shadow: none !important; margin: 0 !important; line-height: 1; }
.rd-planning-submit { background: #4f46e5; color: #fff; border: none; border-radius: 14px; padding: 11px 24px; font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 800; cursor: pointer; white-space: nowrap; box-shadow: 0 4px 18px rgba(79,70,229,.38); transition: all .2s; }
.rd-planning-submit:hover { background: #4338ca; transform: translateY(-1px); }

/* ── COCKPIT ──────────────────────────────── */
.rd-cockpit { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 28px; }
.rd-ck {
  background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 18px;
  padding: 14px 16px 12px; position: relative; overflow: hidden;
  cursor: default; transition: transform .3s, border-color .3s;
}
.rd-ck:hover { transform: translateY(-3px); border-color: var(--rd-cbh); }
.rd-ck-lbl { font-family: 'Poppins',sans-serif; font-size: 8px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; display: block; margin-bottom: 8px; }
.rd-ck-lbl.blue { color: #60a5fa; } .rd-ck-lbl.orange { color: #fb923c; } .rd-ck-lbl.em { color: var(--rd-em); } .rd-ck-lbl.amber { color: var(--rd-amber); }
.rd-ck-main { font-family: 'Poppins',sans-serif; font-size: 32px; font-weight: 900; color: #fff; line-height: 1; }
.rd-ck-unit { font-size: 11px; font-weight: 700; color: var(--rd-w55); margin-left: 3px; }
.rd-ck-sub  { font-size: 9px; color: var(--rd-w55); margin-top: 4px; text-align: right; display: flex; flex-direction: column; gap: 2px; }
.rd-ck-sub span { display: flex; align-items: center; justify-content: flex-end; gap: 4px; }
.rd-ck-text1 { font-family: 'Poppins',sans-serif; font-size: 17px; font-weight: 900; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rd-nutri { width: 38px; height: 38px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-size: 17px; font-weight: 900; color: #fff; float: right; margin: -2px -2px 0 0; }
.rd-nutri-A{background:#10b981;} .rd-nutri-B{background:#84cc16;} .rd-nutri-C{background:#eab308;color:#1a1a1a;} .rd-nutri-D{background:#f97316;} .rd-nutri-E{background:#ef4444;}
.rd-ck-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: rgba(255,255,255,.05); }
.rd-ck-fill { height: 100%; border-radius: 0 2px 0 0; animation: rdFill 1.4s cubic-bezier(.65,0,.35,1) forwards; }
@keyframes rdFill { from{width:0;} }
.rd-ck-fill.blue{background:#60a5fa;} .rd-ck-fill.orange{background:#fb923c;} .rd-ck-fill.em{background:var(--rd-em);} .rd-ck-fill.amber{background:var(--rd-amber);}

/* ── PORTIONS ─────────────────────────────── */
.rd-portions { display: inline-flex; align-items: center; background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 14px; overflow: hidden; }
.rd-pb { width: 38px; height: 38px; background: transparent; border: none; color: var(--rd-em); font-size: 20px; font-weight: 900; cursor: pointer; transition: background .2s; }
.rd-pb:hover { background: var(--rd-em-d); }
.rd-pv { padding: 0 12px; border-left: 1px solid var(--rd-w12); border-right: 1px solid var(--rd-w12); text-align: center; }
.rd-pv-unit {
  font-family: 'Poppins',sans-serif; font-size: 9px; font-weight: 700;
  color: var(--rd-em); letter-spacing: .5px;
  display: block; text-align: center; text-transform: none;
}

/* ── INGRÉDIENTS ──────────────────────────── */
.rd-sec-sep { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.rd-sec-sep-line { flex: 1; height: 1px; background: linear-gradient(90deg, transparent, var(--rd-em-m), transparent); }
.rd-sec-badge { display: inline-block; background: var(--rd-em-d); border: 1px solid var(--rd-em-m); border-radius: 8px; padding: 4px 12px; margin-bottom: 0; font-family: 'Poppins',sans-serif; font-size: 8px; font-weight: 700; color: var(--rd-em); text-transform: uppercase; letter-spacing: 2px; white-space: nowrap; }
.rd-ingr-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.rd-ic { background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 16px; padding: 12px; display: flex; align-items: center; gap: 10px; transition: all .25s; cursor: default; }
.rd-ic:hover { border-color: var(--rd-cbh); transform: translateY(-3px); }
.rd-ic-img { width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0; background: rgba(255,255,255,.03); border: 1px solid var(--rd-w06); display: flex; align-items: center; justify-content: center; font-size: 20px; transition: transform .3s; overflow: hidden; }
.rd-ic:hover .rd-ic-img { transform: rotate(8deg); }
.rd-ic-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rd-ic-name { font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 700; color: #fff; margin-bottom: 3px; }
.rd-ic-qty  { display: flex; align-items: baseline; gap: 4px; flex-wrap: wrap; }
.rd-ic-num  { font-family: 'Poppins',sans-serif; font-size: 17px; font-weight: 900; color: var(--rd-em); }
.rd-ic-unit { font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 500; color: rgba(52,211,153,.65); text-transform: none; letter-spacing: .3px; white-space: nowrap; }
.rd-ic-note { font-size: 9px; color: var(--rd-w30); font-style: italic; margin-top: 2px; }
.rd-ic-opt  { font-size: 7px; font-weight: 800; color: rgba(147,197,253,.9); background: rgba(59,130,246,.1); border: 1px solid rgba(59,130,246,.15); border-radius: 4px; padding: 1px 5px; margin-left: 4px; }

/* ── ÉTAPES ───────────────────────────────── */
.rd-step { background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 24px; overflow: hidden; display: flex; margin-bottom: 16px; transition: border-color .3s, box-shadow .3s; }
.rd-step:hover { border-color: rgba(52,211,153,.22); box-shadow: 0 16px 44px rgba(0,0,0,.35); }
.rd-step-n { width: 64px; flex-shrink: 0; background: rgba(52,211,153,.05); border-right: 1px solid rgba(52,211,153,.1); display: flex; align-items: flex-start; justify-content: center; padding-top: 26px; }
.rd-step-num { width: 38px; height: 38px; border-radius: 12px; background: var(--rd-em-d); border: 1px solid rgba(52,211,153,.28); display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-size: 16px; font-weight: 900; color: var(--rd-em); }
.rd-step-b { flex: 1; padding: 22px 26px; }
.rd-step-lbl { font-family: 'Poppins',sans-serif; font-size: 8px; font-weight: 700; color: var(--rd-w30); text-transform: uppercase; letter-spacing: 3px; margin-bottom: 12px; }
.rd-step-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.rd-step-pill { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; background: rgba(255,255,255,.04); border: 1px solid var(--rd-w12); font-size: 10px; font-weight: 600; color: var(--rd-w75); }
.rd-step-pill img { width: 16px; height: 16px; object-fit: contain; }
.rd-step-txt { font-family: 'DM Sans',sans-serif; font-size: 15px; color: var(--rd-w75); line-height: 1.85; }
.rd-step-img { width: 100%; border-radius: 16px; margin-bottom: 18px; object-fit: cover; max-height: 360px; border: 1px solid var(--rd-cb); }
.rd-empty-steps { text-align: center; padding: 56px 24px; background: var(--rd-card); border: 2px dashed rgba(255,255,255,.06); border-radius: 22px; }

/* ── COMMENTAIRES ─────────────────────────── */
.rd-cmt-bg { background: linear-gradient(to bottom,rgba(6,16,10,.9),rgba(3,12,7,.98)); border-top: 1px solid var(--rd-w06); padding: 64px 0 88px; }
.rd-cmt-wrap { max-width: 860px; margin: 0 auto; padding: 0 32px; }
.rd-cmt-hd { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 40px; flex-wrap: wrap; gap: 16px; }
.rd-cmt-title { font-family: 'Poppins',sans-serif; font-size: 28px; font-weight: 900; color: #fff; margin-bottom: 8px; }
.rd-btn-rate { display: inline-flex; align-items: center; gap: 8px; background: var(--rd-em-d); border: 1px solid var(--rd-em-m); border-radius: 14px; padding: 11px 22px; cursor: pointer; transition: all .2s; font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; color: var(--rd-em); }
.rd-btn-rate:hover { background: rgba(52,211,153,.18); }
.rd-btn-already { background: rgba(52,211,153,.1); border: 1px solid rgba(52,211,153,.2); border-radius: 14px; padding: 11px 20px; font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; color: var(--rd-em); }
.rd-avis-form { background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 24px; padding: 28px; margin-bottom: 32px; }
.rd-af-title { font-family: 'Poppins',sans-serif; font-size: 17px; font-weight: 900; color: #fff; margin-bottom: 22px; }
.rd-stars-wrap { background: rgba(255,255,255,.02); border: 1px solid var(--rd-w06); border-radius: 18px; padding: 24px; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.star-item { position: relative; width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: transform .2s; }
.star-item:hover { transform: scale(1.2) rotate(5deg); }
.star-bg  { position: absolute; width: 100%; height: 100%; color: rgba(255,255,255,.12); }
.star-fill { position: absolute; width: 0; height: 100%; overflow: hidden; transition: width .2s; color: #f59e0b; }
.star-item.filled .star-fill { width: 100%; }
.star-item.half-filled .star-fill { width: 50%; }
.rd-af-textarea { width: 100%; background: rgba(255,255,255,.03); border: 1px solid var(--rd-w12); border-radius: 14px; padding: 14px 16px; color: var(--rd-w75); font-size: 14px; line-height: 1.7; font-family: 'DM Sans',sans-serif; resize: vertical; min-height: 96px; outline: none; transition: border-color .2s; }
.rd-af-textarea:focus { border-color: rgba(52,211,153,.28); }
.rd-xp-row { display: flex; justify-content: space-between; align-items: center; margin: 10px 0 6px; }
.rd-xp-msg   { font-size: 10px; font-weight: 700; color: var(--rd-w55); }
.rd-xp-count { font-size: 10px; font-weight: 900; color: var(--rd-em); background: var(--rd-em-d); padding: 3px 10px; border-radius: 8px; }
.rd-xp-wrap  { background: rgba(255,255,255,.06); border-radius: 999px; height: 4px; }
.rd-xp-bar   { background: var(--rd-em); height: 100%; border-radius: 999px; width: 0; box-shadow: 0 0 12px rgba(52,211,153,.35); transition: width .5s; }
.rd-af-footer { display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px; }
.rd-af-cancel { padding: 10px 20px; color: var(--rd-w55); background: none; border: none; cursor: pointer; font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; transition: color .2s; }
.rd-af-cancel:hover { color: #fff; }
.rd-af-submit { padding: 11px 26px; background: var(--rd-em-d); border: 1px solid var(--rd-em-m); border-radius: 13px; color: var(--rd-em); font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 800; cursor: pointer; transition: all .2s; }
.rd-af-submit:hover { background: rgba(52,211,153,.22); }
.rd-cmt { background: var(--rd-card); border: 1px solid var(--rd-cb); border-radius: 22px; padding: 22px 24px; margin-bottom: 12px; transition: border-color .2s; }
.rd-cmt:hover { border-color: rgba(52,211,153,.16); }
.rd-cmt-hd    { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.rd-cmt-av    { width: 42px; height: 42px; border-radius: 13px; overflow: hidden; border: 1.5px solid rgba(52,211,153,.18); flex-shrink: 0; }
.rd-cmt-av img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rd-cmt-name  { font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 800; color: #fff; text-decoration: none; display: block; transition: color .2s; }
.rd-cmt-name:hover { color: var(--rd-em); }
.rd-cmt-time  { font-size: 10px; color: var(--rd-w30); margin-top: 2px; }
.rd-cmt-text  { font-size: 14px; color: var(--rd-w75); line-height: 1.8; margin-bottom: 16px; }
.rd-cmt-ft    { display: flex; align-items: center; gap: 12px; padding-top: 12px; border-top: 1px solid var(--rd-w06); }
.rd-like-btn  { display: inline-flex; align-items: center; gap: 6px; font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 700; color: var(--rd-w55); background: none; border: none; cursor: pointer; padding: 5px 10px; border-radius: 8px; transition: all .2s; }
.rd-like-btn:hover { color: var(--rd-em); background: var(--rd-em-d); }
.rd-like-btn.liked { color: var(--rd-em); }
.rd-reply-btn { font-family: 'Poppins',sans-serif; font-size: 10px; font-weight: 700; color: var(--rd-w30); background: none; border: none; cursor: pointer; text-transform: uppercase; letter-spacing: 1px; transition: color .2s; }
.rd-reply-btn:hover { color: var(--rd-em); }
.rd-delete-btn { font-size: 10px; color: var(--rd-w30); background: none; border: none; cursor: pointer; transition: color .2s; margin-left: auto; }
.rd-delete-btn:hover { color: #fca5a5; }
.rd-replies { margin-top: 10px; padding-left: 22px; border-left: 2px solid rgba(52,211,153,.1); }
.rd-reply { background: rgba(255,255,255,.02); border: 1px solid var(--rd-w06); border-radius: 12px; padding: 10px 14px; margin-bottom: 7px; }
.rd-reply-form { display: flex; gap: 8px; margin-top: 10px; }
.rd-reply-ta { flex: 1; background: rgba(255,255,255,.03); border: 1px solid var(--rd-w12); border-radius: 10px; padding: 8px 12px; color: var(--rd-w75); font-size: 13px; font-family: 'DM Sans',sans-serif; resize: none; outline: none; }
.rd-reply-ta:focus { border-color: rgba(52,211,153,.25); }
.rd-reply-submit { background: var(--rd-card); border: 1px solid var(--rd-cb); color: var(--rd-em); border-radius: 10px; padding: 0 13px; font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 800; cursor: pointer; }
.rd-load-more-wrap { text-align: center; margin-top: 22px; }
.rd-load-more { background: transparent; border: 1px solid rgba(52,211,153,.2); border-radius: 13px; padding: 11px 26px; color: var(--rd-em); font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; cursor: pointer; transition: all .2s; }
.rd-load-more:hover { background: var(--rd-em-d); }
.rd-login-cta { background: rgba(255,255,255,.04); border: 1px solid var(--rd-w12); border-radius: 13px; padding: 11px 20px; color: var(--rd-w75); text-decoration: none; font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; transition: all .2s; }
.rd-login-cta:hover { background: rgba(255,255,255,.08); }

/* ── MODALES ──────────────────────────────── */
.rd-modal { position: fixed; inset: 0; background: rgba(3,12,7,.88); backdrop-filter: blur(10px); display: none; align-items: center; justify-content: center; z-index: 100; padding: 16px; }
.rd-modal.flex { display: flex; }
.rd-modal-box { background: rgba(14,36,22,.98); border: 1px solid rgba(52,211,153,.16); border-radius: 26px; max-width: 380px; width: 100%; padding: 34px; box-shadow: 0 40px 100px rgba(0,0,0,.6); }
.rd-modal-icon { width: 68px; height: 68px; border-radius: 20px; display: flex; align-items: center; justify-content: center; font-size: 30px; margin: 0 auto 18px; }
.rd-modal-title { font-family: 'Poppins',sans-serif; font-size: 20px; font-weight: 900; color: #fff; text-align: center; margin-bottom: 8px; }
.rd-modal-sub { font-size: 13px; color: var(--rd-w55); text-align: center; margin-bottom: 26px; line-height: 1.7; }
.rd-cnt-row { display: flex; align-items: center; justify-content: center; gap: 20px; background: rgba(255,255,255,.03); border: 1px solid var(--rd-w06); border-radius: 18px; padding: 18px; margin-bottom: 24px; }
.rd-cnt-btn { width: 46px; height: 46px; border-radius: 13px; background: rgba(255,255,255,.05); border: 1px solid var(--rd-w12); color: var(--rd-em); font-size: 22px; font-weight: 900; cursor: pointer; transition: all .2s; }
.rd-cnt-btn:hover { background: var(--rd-em-d); }
.rd-cnt-num { font-family: 'Poppins',sans-serif; font-size: 42px; font-weight: 900; color: #fff; min-width: 58px; text-align: center; line-height: 1; }
.rd-cnt-unit { font-size: 10px; font-weight: 700; color: var(--rd-w30); text-transform: uppercase; letter-spacing: 1px; display: block; text-align: center; }
.rd-modal-confirm { width: 100%; border: none; border-radius: 15px; padding: 15px; font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 800; cursor: pointer; margin-bottom: 10px; transition: all .2s; }
.rd-modal-cancel  { width: 100%; background: none; border: none; padding: 10px; color: var(--rd-w30); font-family: 'Poppins',sans-serif; font-size: 12px; font-weight: 700; cursor: pointer; transition: color .2s; }
.rd-modal-cancel:hover { color: var(--rd-w55); }
.rd-modal-box.red { border-color: rgba(239,68,68,.2); }

/* ── REVEAL ───────────────────────────────── */
.rd-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.rd-reveal.visible { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width: 1023px) {
  .rd-cockpit { grid-template-columns: repeat(2,1fr); }
  .rd-ingr-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 767px) {
  .rd-hero { height: 60vh; min-height: 400px; }
  .rd-hero-content { padding: 0 16px 36px; }
  .rd-title { letter-spacing: -.5px; }
  .rd-desc-hero { font-size: 14px; padding: 12px 14px; }
  .rd-hero-btns .rd-hero-btn { width: 44px; height: 44px; font-size: 19px; }
  .rd-author-zone { padding: 0 16px; }
  .rd-author-row { gap: 10px; }
  .rd-author-card { padding: 10px 16px 10px 10px; border-radius: 18px; }
  .rd-author-av { width: 42px; height: 42px; }
  .rd-rating-chip { padding: 10px 14px; border-radius: 18px; }
  .rd-rating-num { font-size: 22px; }
  .rd-edit-btns { width: 100%; }
  .rd-wrap { padding: 22px 16px 72px; }
  .rd-planning { flex-direction: column; align-items: stretch; border-radius: 16px; }
  .rd-planning-lbl { padding: 8px 12px; gap: 8px; }
  .rd-planning-ico { width: 32px; height: 32px; font-size: 16px; border-radius: 10px; }
  .rd-planning-title { font-size: 13px; }
  .rd-planning-sub { font-size: 8px; }
  .rd-planning-form { flex-direction: row; flex-wrap: wrap; margin: 0 3px 3px; border-radius: 14px; padding: 4px; gap: 2px; }
  .rd-pf-field { padding: 6px 12px; flex: 1; min-width: 0; }
  .custom-input-wrapper input, .custom-input-wrapper select { font-size: .85rem; }
  .rd-planning-submit { flex-basis: 100%; width: 100%; border-radius: 11px; padding: 10px 16px; margin: 4px 0 0 0; font-size: 13px; }
  .rd-cockpit { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .rd-ck { padding: 12px 13px 10px; border-radius: 15px; }
  .rd-ck-main { font-size: 26px; }
  .rd-ck-text1 { font-size: 14px; }
  .rd-nutri { width: 32px; height: 32px; font-size: 14px; }
  .rd-sh { flex-wrap: nowrap; gap: 10px; margin-bottom: 18px; }
  .rd-sh-title { font-size: 19px; }
  .rd-ingr-grid { grid-template-columns: repeat(2,1fr); gap: 8px; }
  .rd-ic { padding: 10px; gap: 8px; border-radius: 14px; }
  .rd-ic-img { width: 38px; height: 38px; font-size: 18px; border-radius: 10px; }
  .rd-ic-name { font-size: 10px; }
  .rd-ic-num  { font-size: 14px; }
  .rd-ic-unit { font-size: 11px; }
  .rd-step { flex-direction: column; border-radius: 20px; }
  .rd-step-n { width: 100%; padding: 14px 16px 8px; flex-direction: row; align-items: center; gap: 10px; justify-content: flex-start; border-right: none; border-bottom: 1px solid rgba(52,211,153,.1); }
  .rd-step-b { padding: 16px 18px 20px; }
  .rd-step-txt { font-size: 14px; }
  .rd-cmt-bg { padding: 44px 0 64px; }
  .rd-cmt-wrap { padding: 0 16px; }
  .rd-cmt-title { font-size: 22px; }
  .rd-cmt-hd { margin-bottom: 28px; }
  .rd-avis-form { padding: 20px; }
  .rd-cmt { padding: 16px 18px; border-radius: 18px; }
  .rd-modal-box { padding: 26px 22px; border-radius: 22px; }
}
@media (max-width: 479px) {
  .rd-ingr-grid { grid-template-columns: 1fr 1fr; }
  .rd-ic { padding: 8px; gap: 7px; }
  .rd-ic-img { width: 34px; height: 34px; font-size: 16px; border-radius: 9px; }
  .rd-cockpit { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════
   LIGHT MODE OVERRIDES
═══════════════════════════════════════════ */
[data-theme="light"] .rd-page {
  background: #f2faf5;
  color: #0a1f12;
}
[data-theme="light"] :root,
[data-theme="light"] .rd-page {
  --rd-bg:   #f2faf5;
  --rd-card: rgba(255,255,255,0.92);
  --rd-cb:   rgba(52,211,153,0.22);
  --rd-cbh:  rgba(52,211,153,0.45);
  --rd-w100: #0a1f12;
  --rd-w75:  rgba(10,31,18,0.70);
  --rd-w55:  rgba(10,31,18,0.55);
  --rd-w30:  rgba(10,31,18,0.40);
  --rd-w12:  rgba(10,31,18,0.10);
  --rd-w06:  rgba(10,31,18,0.06);
}
[data-theme="light"] .rd-hero-ov {
  background: linear-gradient(to top,#f2faf5 0%,rgba(240,250,244,.7) 28%,rgba(0,0,0,.1) 62%,rgba(0,0,0,.25) 100%);
}

/* ── CORRECTION DU TITRE EN MODE CLAIR ── */
[data-theme="light"] .rd-title { color: #0a1f12; text-shadow: none; }

[data-theme="light"] .rd-desc-hero {
  color: #000000;
  background: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .rd-author-card,
[data-theme="light"] .rd-rating-chip {
  background: rgba(255,255,255,0.95);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
[data-theme="light"] .rd-author-name,
[data-theme="light"] .rd-cmt-name,
[data-theme="light"] .rd-cmt-title,
[data-theme="light"] .rd-sh-title,
[data-theme="light"] .rd-modal-title,
[data-theme="light"] .rd-af-title,
[data-theme="light"] .rd-ck-main,
[data-theme="light"] .rd-ck-text1,
[data-theme="light"] .rd-cnt-num,
[data-theme="light"] .rd-rating-count,
[data-theme="light"] #nb-personnes { color: #0a1f12 !important; }
[data-theme="light"] .rd-cnt-btn {
  background: rgba(10,31,18,0.05);
  border-color: rgba(10,31,18,0.12);
}
[data-theme="light"] .rd-cnt-btn:hover {
  background: rgba(52,211,153,0.15);
  border-color: rgba(52,211,153,0.3);
}
[data-theme="light"] .star-bg { color: rgba(10, 31, 18, 0.15); }
[data-theme="light"] .rd-ck {
  background: rgba(255,255,255,0.92);
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
[data-theme="light"] .rd-ic { background: rgba(255,255,255,0.92); }
[data-theme="light"] .rd-ic-name { color: #0a1f12; }
[data-theme="light"] .rd-step { background: rgba(255,255,255,0.92); }
[data-theme="light"] .rd-step-txt { color: rgba(10,31,18,0.70); }
[data-theme="light"] .rd-step-pill { background: rgba(10,31,18,0.04); color: rgba(10,31,18,0.65); }
[data-theme="light"] .rd-empty-steps { background: rgba(255,255,255,0.92); }
[data-theme="light"] .rd-cmt-bg { background: linear-gradient(to bottom,rgba(242,250,245,.95),rgba(235,248,241,.99)); border-top: 1px solid rgba(52,211,153,0.15); }
[data-theme="light"] .rd-cmt,
[data-theme="light"] .rd-avis-form { background: rgba(255,255,255,0.95); }
[data-theme="light"] .rd-reply { background: rgba(52,211,153,0.04); }
[data-theme="light"] .rd-af-textarea { background: rgba(255,255,255,0.95); color: rgba(10,31,18,0.75); border-color: rgba(10,31,18,0.12); }
[data-theme="light"] .rd-modal { background: rgba(10,31,18,0.55); }
[data-theme="light"] .rd-modal-box { background: rgba(255,255,255,0.98); border-color: rgba(52,211,153,0.25); }
[data-theme="light"] .rd-modal-sub { color: rgba(10,31,18,0.55); }
[data-theme="light"] .rd-cnt-row { background: rgba(10,31,18,0.03); border-color: rgba(10,31,18,0.08); }
[data-theme="light"] .hp-toast { background: rgba(255,255,255,0.97); }
[data-theme="light"] .hp-toast-msg { color: #0a1f12; }
[data-theme="light"] .rd-load-more { border-color: rgba(52,211,153,0.35); }
[data-theme="light"] .rd-modal-cancel { color: rgba(10,31,18,0.45); }

/* ── STYLE FRACTIONS ────────────────────────── */
.rd-fraction {
  font-size: 0.65em;
  font-weight: 500;
  margin-left: 3px;
  opacity: 0.9;
}
/* ════════════════════════════════════════════════════
   PRÉPARATION "SCÈNE DE CUISINE" — Night Kitchen v2
   Supporte data-theme="dark" (défaut) et "light"
════════════════════════════════════════════════════ */

/* ── Variables locales ─────────────────────────── */
:root,
[data-theme="dark"] {
  --rd-nk-bg:       #03140c;
  --rd-nk-card:     rgba(255,255,255,0.035);
  --rd-nk-card-act: rgba(52,211,153,0.045);
  --rd-nk-card-don: rgba(16,185,129,0.02);
  --rd-nk-brd:      rgba(255,255,255,0.05);
  --rd-nk-brd-act:  rgba(52,211,153,0.18);
  --rd-nk-brd-don:  rgba(52,211,153,0.07);
  --rd-nk-rail:     rgba(255,255,255,0.05);
  --rd-nk-t1:       #ffffff;
  --rd-nk-t2:       rgba(255,255,255,0.65);
  --rd-nk-t3:       rgba(255,255,255,0.38);
  --rd-nk-t4:       rgba(255,255,255,0.14);
  --rd-nk-t5:       rgba(255,255,255,0.06);
  --rd-nk-circ-bg:  rgba(255,255,255,0.03);
  --rd-nk-circ-brd: rgba(255,255,255,0.08);
  --rd-nk-chip-bg:  rgba(255,255,255,0.035);
  --rd-nk-chip-brd: rgba(255,255,255,0.065);
  --rd-nk-chip-t:   rgba(255,255,255,0.72);
  --rd-nk-chip-qty: rgba(255,255,255,0.35);
  --rd-nk-ghost:    rgba(255,255,255,0.02);
  --rd-nk-ghost-act:rgba(52,211,153,0.035);
  --rd-nk-timer-bg: rgba(245,158,11,0.07);
  --rd-nk-timer-brd:rgba(245,158,11,0.20);
  --rd-nk-timer-c:  #f59e0b;
  --rd-nk-done-bg:  rgba(52,211,153,0.08);
  --rd-nk-done-brd: rgba(52,211,153,0.22);
  --rd-nk-focus-bg: rgba(255,255,255,0.03);
  --rd-nk-focus-brd:rgba(255,255,255,0.07);
  --rd-nk-focus-c:  rgba(255,255,255,0.38);
  --rd-nk-cmp-bg:   linear-gradient(135deg,rgba(52,211,153,0.09),rgba(16,185,129,0.04));
  --rd-nk-cmp-brd:  rgba(52,211,153,0.25);
  --rd-nk-cmp-xp-bg:rgba(245,158,11,0.08);
  --rd-nk-cmp-xp-brd:rgba(245,158,11,0.20);
  --rd-nk-cm-bg:    rgba(2,12,7,0.98);
  --rd-nk-cm-top-brd:rgba(52,211,153,0.07);
  --rd-nk-cm-ghost: rgba(52,211,153,0.028);
  --rd-nk-cm-lbl-c: rgba(52,211,153,0.45);
  --rd-nk-cm-lbl-line:rgba(52,211,153,0.4);
  --rd-nk-cm-txt:   rgba(255,255,255,0.82);
  --rd-nk-cm-close: rgba(255,255,255,0.05);
  --rd-nk-cm-close-brd:rgba(255,255,255,0.09);
  --rd-nk-cm-close-c:rgba(255,255,255,0.4);
  --rd-nk-cm-dot:   rgba(255,255,255,0.10);
  --rd-nk-cm-dot-done:rgba(52,211,153,0.4);
  --rd-nk-cm-mark-bg:rgba(52,211,153,0.07);
  --rd-nk-cm-mark-brd:rgba(52,211,153,0.2);
  --rd-nk-cm-prev-bg:rgba(255,255,255,0.04);
  --rd-nk-cm-prev-brd:rgba(255,255,255,0.09);
  --rd-nk-cm-prev-c:rgba(255,255,255,0.4);
  --rd-nk-sticky-bg:rgba(3,20,12,0.92);
  --rd-nk-strip-lbl:rgba(255,255,255,0.22);
  --rd-nk-ing-av-bg:rgba(255,255,255,0.06);
  --rd-nk-ing-av-brd:rgba(255,255,255,0.10);
}

[data-theme="light"] {
  --rd-nk-bg:       #f4faf6;
  --rd-nk-card:     rgba(255,255,255,0.80);
  --rd-nk-card-act: rgba(5,150,105,0.06);
  --rd-nk-card-don: rgba(5,150,105,0.02);
  --rd-nk-brd:      rgba(10,31,18,0.08);
  --rd-nk-brd-act:  rgba(5,150,105,0.28);
  --rd-nk-brd-don:  rgba(5,150,105,0.10);
  --rd-nk-rail:     rgba(10,31,18,0.08);
  --rd-nk-t1:       #0a1f12;
  --rd-nk-t2:       rgba(10,31,18,0.70);
  --rd-nk-t3:       rgba(10,31,18,0.45);
  --rd-nk-t4:       rgba(10,31,18,0.20);
  --rd-nk-t5:       rgba(10,31,18,0.05);
  --rd-nk-circ-bg:  rgba(255,255,255,0.60);
  --rd-nk-circ-brd: rgba(10,31,18,0.14);
  --rd-nk-chip-bg:  rgba(255,255,255,0.80);
  --rd-nk-chip-brd: rgba(10,31,18,0.10);
  --rd-nk-chip-t:   rgba(10,31,18,0.75);
  --rd-nk-chip-qty: rgba(10,31,18,0.40);
  --rd-nk-ghost:    rgba(10,31,18,0.03);
  --rd-nk-ghost-act:rgba(5,150,105,0.05);
  --rd-nk-timer-bg: rgba(180,83,9,0.06);
  --rd-nk-timer-brd:rgba(180,83,9,0.20);
  --rd-nk-timer-c:  #92400e;
  --rd-nk-done-bg:  rgba(5,150,105,0.08);
  --rd-nk-done-brd: rgba(5,150,105,0.25);
  --rd-nk-focus-bg: rgba(10,31,18,0.04);
  --rd-nk-focus-brd:rgba(10,31,18,0.10);
  --rd-nk-focus-c:  rgba(10,31,18,0.45);
  --rd-nk-cmp-bg:   linear-gradient(135deg,rgba(5,150,105,0.07),rgba(16,185,129,0.03));
  --rd-nk-cmp-brd:  rgba(5,150,105,0.22);
  --rd-nk-cmp-xp-bg:rgba(180,83,9,0.07);
  --rd-nk-cmp-xp-brd:rgba(180,83,9,0.20);
  --rd-nk-cm-bg:    rgba(244,250,246,0.98);
  --rd-nk-cm-top-brd:rgba(5,150,105,0.10);
  --rd-nk-cm-ghost: rgba(5,150,105,0.04);
  --rd-nk-cm-lbl-c: #059669;
  --rd-nk-cm-lbl-line:rgba(5,150,105,0.4);
  --rd-nk-cm-txt:   rgba(10,31,18,0.85);
  --rd-nk-cm-close: rgba(10,31,18,0.05);
  --rd-nk-cm-close-brd:rgba(10,31,18,0.12);
  --rd-nk-cm-close-c:rgba(10,31,18,0.45);
  --rd-nk-cm-dot:   rgba(10,31,18,0.10);
  --rd-nk-cm-dot-done:rgba(5,150,105,0.4);
  --rd-nk-cm-mark-bg:rgba(5,150,105,0.07);
  --rd-nk-cm-mark-brd:rgba(5,150,105,0.22);
  --rd-nk-cm-prev-bg:rgba(10,31,18,0.04);
  --rd-nk-cm-prev-brd:rgba(10,31,18,0.10);
  --rd-nk-cm-prev-c:rgba(10,31,18,0.45);
  --rd-nk-sticky-bg:rgba(244,250,246,0.92);
  --rd-nk-strip-lbl:rgba(10,31,18,0.28);
  --rd-nk-ing-av-bg:rgba(10,31,18,0.05);
  --rd-nk-ing-av-brd:rgba(10,31,18,0.10);
}

/* ── Barre de progression sticky ─────────────── */
.rd-prog-bar {
  position: fixed; top: 0; left: 0; right: 0;
  height: 3px; background: rgba(255,255,255,0.06); z-index: 500;
  pointer-events: none;
}
[data-theme="light"] .rd-prog-bar { background: rgba(10,31,18,0.07); }
.rd-prog-fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, #10b981, #34d399);
  transition: width 0.5s cubic-bezier(.34,1.2,.64,1);
  box-shadow: 0 0 12px rgba(52,211,153,.5);
}
.rd-sticky-step {
  position: fixed; top: 12px; right: 16px;
  display: flex; align-items: center; gap: 8px;
  background: var(--rd-nk-sticky-bg);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(52,211,153,0.18); border-radius: 999px;
  padding: 6px 14px 6px 8px;
  font-family: 'Poppins', sans-serif; font-size: 11px; font-weight: 700;
  color: #34d399; z-index: 500;
  opacity: 0; transform: translateY(-10px);
  transition: opacity .3s ease, transform .3s ease; pointer-events: none;
}
[data-theme="light"] .rd-sticky-step { border-color: rgba(5,150,105,0.22); color: #059669; }
.rd-sticky-step.visible { opacity: 1; transform: translateY(0); }
.rd-sticky-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #34d399; box-shadow: 0 0 6px rgba(52,211,153,.7);
  animation: rd-pulse-d 1.6s ease-in-out infinite; flex-shrink: 0;
}
[data-theme="light"] .rd-sticky-dot { background: #059669; }
@keyframes rd-pulse-d {
  0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(.6);opacity:.4}
}

/* ── Header section ───────────────────────────── */
.rd-prep-hd {
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px; margin-bottom: 36px;
}
.rd-prep-hd-left { display: flex; align-items: center; gap: 14px; }
.rd-prep-hd-icon {
  width: 52px; height: 52px; flex-shrink: 0; border-radius: 17px;
  background: linear-gradient(135deg,#10b981,#34d399);
  display: flex; align-items: center; justify-content: center; font-size: 24px;
  box-shadow: 0 4px 24px rgba(16,185,129,.3), inset 0 1px 0 rgba(255,255,255,.15);
}
.rd-prep-hd-meta {
  font-size: 12px; color: var(--rd-nk-t3); margin-top: 3px; font-weight: 500;
}

/* Bouton Mode Cuisine */
.rd-btn-cm {
  display: flex; align-items: center; gap: 9px;
  padding: 11px 20px;
  background: linear-gradient(135deg,rgba(52,211,153,.1),rgba(16,185,129,.05));
  border: 1px solid rgba(52,211,153,.45); border-radius: 15px;
  font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 800;
  color: #34d399; cursor: pointer; letter-spacing: .3px;
  transition: all .22s ease; white-space: nowrap; flex-shrink: 0;
  text-decoration: none;
}
[data-theme="light"] .rd-btn-cm {
  background: rgba(5,150,105,0.07); border-color: rgba(5,150,105,.35); color: #059669;
}
.rd-btn-cm:hover {
  border-color: #34d399;
  box-shadow: 0 4px 28px rgba(52,211,153,.2); transform: translateY(-2px);
}
[data-theme="light"] .rd-btn-cm:hover { border-color: #059669; }
.rd-btn-cm-ico {
  width: 28px; height: 28px; background: rgba(52,211,153,.14);
  border-radius: 9px; display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
[data-theme="light"] .rd-btn-cm-ico { background: rgba(5,150,105,.1); }

/* ── Rail vertical ────────────────────────────── */
.rd-steps-wrap { position: relative; }
.rd-v-rail {
  position: absolute; left: 24px; top: 26px; bottom: 26px;
  width: 2px; background: var(--rd-nk-rail); border-radius: 2px; overflow: visible;
}
.rd-v-rail-fill {
  position: absolute; top: 0; left: 0; right: 0; height: 0%;
  background: linear-gradient(180deg,#34d399,#10b981); border-radius: 2px;
  transition: height .55s cubic-bezier(.34,1.2,.64,1);
  box-shadow: 0 0 8px rgba(52,211,153,.4);
}

/* ── Step container ───────────────────────────── */
.rd-nk-step {
  display: flex; gap: 0; margin-bottom: 14px; cursor: pointer;
  animation: rd-fadeUp .45s ease both;
}
@keyframes rd-fadeUp {
  from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)}
}
.rd-nk-step:nth-child(2){animation-delay:.05s}
.rd-nk-step:nth-child(3){animation-delay:.10s}
.rd-nk-step:nth-child(4){animation-delay:.15s}
.rd-nk-step:nth-child(5){animation-delay:.20s}
.rd-nk-step:nth-child(6){animation-delay:.25s}
.rd-nk-step:nth-child(n+7){animation-delay:.30s}

/* Numéro cercle */
.rd-nk-nc {
  display: flex; flex-direction: column; align-items: center;
  flex-shrink: 0; width: 48px; position: relative; z-index: 1; padding-top: 3px;
}
.rd-nk-circ {
  width: 48px; height: 48px; border-radius: 50%;
  border: 2px solid var(--rd-nk-circ-brd);
  background: var(--rd-nk-circ-bg);
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 1;
  transition: all .35s cubic-bezier(.34,1.4,.64,1);
}
.rd-nk-circ-num {
  font-family: 'Poppins', sans-serif; font-size: 15px; font-weight: 800;
  color: var(--rd-nk-t4); transition: all .2s ease;
}
.rd-nk-circ-check {
  display: none; font-size: 18px; color: #34d399;
}
[data-theme="light"] .rd-nk-circ-check { color: #059669; }

.rd-nk-step.done .rd-nk-circ {
  background: rgba(16,185,129,.1); border-color: rgba(52,211,153,.3);
}
[data-theme="light"] .rd-nk-step.done .rd-nk-circ {
  background: rgba(5,150,105,.1); border-color: rgba(5,150,105,.3);
}
.rd-nk-step.done .rd-nk-circ-num { display: none; }
.rd-nk-step.done .rd-nk-circ-check { display: block; }

.rd-nk-step.active .rd-nk-circ {
  background: linear-gradient(135deg,rgba(52,211,153,.22),rgba(16,185,129,.1));
  border-color: #34d399; border-width: 2px;
  box-shadow: 0 0 0 5px rgba(52,211,153,.1), 0 4px 24px rgba(52,211,153,.25);
  transform: scale(1.1);
}
[data-theme="light"] .rd-nk-step.active .rd-nk-circ {
  background: linear-gradient(135deg,rgba(5,150,105,.15),rgba(16,185,129,.07));
  border-color: #059669;
  box-shadow: 0 0 0 5px rgba(5,150,105,.1), 0 4px 24px rgba(5,150,105,.2);
}
.rd-nk-step.active .rd-nk-circ-num { color: #34d399; }
[data-theme="light"] .rd-nk-step.active .rd-nk-circ-num { color: #059669; }

/* Corps */
.rd-nk-bd { flex: 1; margin-left: 14px; }
.rd-nk-inner {
  background: var(--rd-nk-card);
  border: 1px solid var(--rd-nk-brd);
  border-radius: 22px; padding: 20px 24px;
  position: relative; overflow: hidden;
  transition: background .3s ease, border-color .3s ease, box-shadow .3s ease, opacity .3s ease;
}
.rd-nk-step.active .rd-nk-inner {
  background: var(--rd-nk-card-act);
  border-color: var(--rd-nk-brd-act);
  box-shadow: 0 8px 48px rgba(0,0,0,.2), inset 0 1px 0 rgba(52,211,153,.07);
}
[data-theme="light"] .rd-nk-step.active .rd-nk-inner {
  box-shadow: 0 8px 32px rgba(0,0,0,.07), inset 0 1px 0 rgba(5,150,105,.05);
}
.rd-nk-step.done .rd-nk-inner {
  background: var(--rd-nk-card-don);
  border-color: var(--rd-nk-brd-don);
}
/* Barre gauche verte active */
.rd-nk-inner::before {
  content: ''; position: absolute; left: 0; top: 20px; bottom: 20px;
  width: 4px; border-radius: 0 4px 4px 0;
  background: linear-gradient(180deg,#34d399,#10b981);
  opacity: 0; transition: opacity .3s ease;
}
[data-theme="light"] .rd-nk-inner::before {
  background: linear-gradient(180deg,#059669,#10b981);
}
.rd-nk-step.active .rd-nk-inner::before { opacity: 1; }
/* Ligne top shimmer */
.rd-nk-inner::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,transparent,rgba(52,211,153,.25),transparent);
  opacity: 0; transition: opacity .3s ease;
}
.rd-nk-step.active .rd-nk-inner::after { opacity: 1; }

/* Numéro fantôme */
.rd-nk-ghost {
  position: absolute; right: -8px; top: -18px;
  font-family: 'Poppins', sans-serif; font-size: 130px; font-weight: 900;
  color: var(--rd-nk-ghost); line-height: 1;
  pointer-events: none; user-select: none; transition: color .3s ease;
}
.rd-nk-step.active .rd-nk-ghost { color: var(--rd-nk-ghost-act); }

/* Check badge */
.rd-nk-done-check {
  position: absolute; top: 14px; right: 14px;
  width: 30px; height: 30px;
  background: rgba(16,185,129,.12); border: 1.5px solid rgba(52,211,153,.3);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: #34d399;
  opacity: 0; transform: scale(.4) rotate(-30deg);
  transition: all .4s cubic-bezier(.34,1.6,.64,1);
}
[data-theme="light"] .rd-nk-done-check { color: #059669; border-color: rgba(5,150,105,.3); }
.rd-nk-step.done .rd-nk-done-check { opacity: 1; transform: scale(1) rotate(0deg); }

/* Label */
.rd-nk-lbl {
  display: flex; align-items: center; gap: 7px;
  font-family: 'Poppins', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--rd-nk-t4); margin-bottom: 10px; transition: color .2s ease;
}
.rd-nk-step.active .rd-nk-lbl { color: #34d399; }
[data-theme="light"] .rd-nk-step.active .rd-nk-lbl { color: #059669; }
.rd-nk-step.done .rd-nk-lbl { color: rgba(52,211,153,.45); }
[data-theme="light"] .rd-nk-step.done .rd-nk-lbl { color: rgba(5,150,105,.5); }
.rd-nk-pulse {
  width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0;
  background: #34d399; animation: rd-pulse-d 1.6s ease-in-out infinite;
}
[data-theme="light"] .rd-nk-pulse { background: #059669; }

/* Image étape */
.rd-nk-img-wrap { margin-bottom: 14px; }
.rd-nk-img {
  width: 100%; max-height: 220px; object-fit: cover;
  border-radius: 14px; display: block;
  border: 1px solid var(--rd-nk-brd);
}

/* Texte */
.rd-nk-txt {
  font-family: 'DM Sans', sans-serif; font-size: 14.5px;
  font-weight: 400; line-height: 1.75;
  color: var(--rd-nk-t2);
}

/* Timer */
.rd-nk-timer {
  display: inline-flex; align-items: center; gap: 7px;
  margin-top: 14px; padding: 6px 13px;
  background: var(--rd-nk-timer-bg); border: 1px solid var(--rd-nk-timer-brd);
  border-radius: 999px;
  font-family: 'Poppins', sans-serif; font-size: 11px; font-weight: 700;
  color: var(--rd-nk-timer-c);
}
.rd-nk-timer span {
  font-size: 11px; font-weight: 500;
  font-family: 'DM Sans', sans-serif;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px;
}

/* ══════════════════════════════════════
   INGREDIENT STRIP
══════════════════════════════════════ */
.rd-ingr-strip {
  display: flex; gap: 9px; flex-wrap: wrap;
  margin-top: 18px; padding-top: 16px;
  border-top: 1px solid var(--rd-nk-brd);
  transition: opacity .3s ease;
}
/* Vide = invisible */
.rd-ingr-strip:empty,
.rd-ingr-strip:has(.rd-ingr-strip-label:only-child) { display: none; }


.rd-ingr-strip-label {
  width: 100%;
  font-family: 'Poppins', sans-serif; font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--rd-nk-strip-lbl); margin-bottom: 2px;
}

/* Chip ingrédient */
.rd-ing-chip {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 12px 5px 5px;
  background: var(--rd-nk-chip-bg); border: 1px solid var(--rd-nk-chip-brd);
  border-radius: 999px; cursor: default;
  transition: all .22s cubic-bezier(.34,1.4,.64,1);
}
.rd-nk-step.active .rd-ing-chip:hover {
  background: rgba(52,211,153,.09); border-color: rgba(52,211,153,.28);
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
[data-theme="light"] .rd-nk-step.active .rd-ing-chip:hover {
  background: rgba(5,150,105,.07); border-color: rgba(5,150,105,.25);
}

.rd-ing-av {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  overflow: hidden; background: var(--rd-nk-ing-av-bg);
  border: 1.5px solid var(--rd-nk-ing-av-brd);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; position: relative;
  transition: border-color .2s ease;
}
.rd-ing-av img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Anneau vert pour ingrédients "clés" */
.rd-nk-step.active .rd-ing-chip.key .rd-ing-av {
  border-color: rgba(52,211,153,.55);
  box-shadow: 0 0 0 2px rgba(52,211,153,.12);
}
[data-theme="light"] .rd-nk-step.active .rd-ing-chip.key .rd-ing-av {
  border-color: rgba(5,150,105,.5);
  box-shadow: 0 0 0 2px rgba(5,150,105,.1);
}

.rd-ing-info { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.rd-ing-name {
  font-family: 'Poppins', sans-serif; font-size: 11.5px; font-weight: 700;
  color: var(--rd-nk-chip-t);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 110px;
  line-height: 1.2;
}
.rd-ing-chip.key .rd-ing-name { color: var(--rd-nk-t2); }
.rd-ing-qty {
  font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 500;
  color: var(--rd-nk-chip-qty); white-space: nowrap; line-height: 1;
}

/* ── Boutons footer étape ─────────────────────── */
.rd-nk-ft {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--rd-nk-brd);
}
.rd-nk-btn-done {
  display: flex; align-items: center; gap: 7px; padding: 9px 16px;
  background: var(--rd-nk-done-bg); border: 1px solid var(--rd-nk-done-brd);
  border-radius: 11px; font-family: 'Poppins', sans-serif;
  font-size: 11px; font-weight: 800; color: #34d399; cursor: pointer;
  text-transform: uppercase; letter-spacing: .5px;
  transition: all .2s ease;
}
[data-theme="light"] .rd-nk-btn-done { color: #059669; }
.rd-nk-btn-done:hover {
  background: rgba(52,211,153,.15);
  transform: translateY(-1px); box-shadow: 0 4px 16px rgba(52,211,153,.15);
}
[data-theme="light"] .rd-nk-btn-done:hover { background: rgba(5,150,105,.12); }
.rd-nk-step.done .rd-nk-btn-done {
  background: transparent; border-color: var(--rd-nk-brd-don);
  color: rgba(52,211,153,.35); pointer-events: none;
}
[data-theme="light"] .rd-nk-step.done .rd-nk-btn-done { color: rgba(5,150,105,.35); }

.rd-nk-btn-focus {
  display: flex; align-items: center; gap: 6px; padding: 9px 13px;
  background: var(--rd-nk-focus-bg); border: 1px solid var(--rd-nk-focus-brd);
  border-radius: 11px; font-family: 'Poppins', sans-serif;
  font-size: 11px; font-weight: 700; color: var(--rd-nk-focus-c);
  cursor: pointer; transition: all .2s ease;
}
.rd-nk-btn-focus:hover { background: rgba(255,255,255,.07); color: var(--rd-nk-t2); }
[data-theme="light"] .rd-nk-btn-focus:hover { background: rgba(10,31,18,.07); }

/* ── Banner complétion ────────────────────────── */
.rd-completion {
  margin-top: 32px; border-radius: 24px; padding: 36px;
  background: var(--rd-nk-cmp-bg); border: 1px solid var(--rd-nk-cmp-brd);
  text-align: center; opacity: 0; transform: translateY(24px) scale(.97);
  transition: all .55s cubic-bezier(.34,1.4,.64,1);
  position: relative; overflow: hidden;
}
.rd-completion::before {
  content: ''; position: absolute; top: -60px; left: 50%; transform: translateX(-50%);
  width: 300px; height: 180px;
  background: radial-gradient(circle,rgba(52,211,153,.12) 0%,transparent 70%);
  pointer-events: none;
}
.rd-completion.show { opacity: 1; transform: translateY(0) scale(1); }
.rd-completion-emoji { font-size: 48px; display: block; margin-bottom: 14px; }
.rd-completion-title {
  font-family: 'Poppins', sans-serif; font-size: 22px; font-weight: 900;
  color: #34d399; margin-bottom: 8px;
}
[data-theme="light"] .rd-completion-title { color: #059669; }
.rd-completion-sub { font-size: 14px; color: var(--rd-nk-t2); }
.rd-completion-xp {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 18px;
  padding: 10px 20px; background: var(--rd-nk-cmp-xp-bg);
  border: 1px solid var(--rd-nk-cmp-xp-brd); border-radius: 999px;
  font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 800;
  color: var(--rd-nk-timer-c);
}

/* ══════════════════════════════════════
   MODE CUISINE OVERLAY
══════════════════════════════════════ */
.rd-cm {
  position: fixed; inset: 0;
  background: var(--rd-nk-cm-bg);
  backdrop-filter: blur(40px) saturate(150%);
  -webkit-backdrop-filter: blur(40px) saturate(150%);
  z-index: 800; display: flex; flex-direction: column;
  opacity: 0; visibility: hidden;
  transition: opacity .4s ease, visibility .4s ease;
}
.rd-cm.open { opacity: 1; visibility: visible; }

.rd-cm-progress { height: 2px; background: rgba(255,255,255,.04); flex-shrink: 0; }
[data-theme="light"] .rd-cm-progress { background: rgba(10,31,18,.06); }
.rd-cm-pfill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg,#10b981,#34d399);
  transition: width .5s ease; box-shadow: 0 0 10px rgba(52,211,153,.5);
}

.rd-cm-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 32px; border-bottom: 1px solid var(--rd-nk-cm-top-brd); flex-shrink: 0;
}
.rd-cm-title {
  font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 700;
  color: var(--rd-nk-cm-lbl-c); text-transform: uppercase; letter-spacing: 2px;
}
.rd-cm-dots { display: flex; gap: 8px; align-items: center; }
.rd-cm-dot {
  height: 7px; border-radius: 4px; width: 7px; cursor: pointer;
  background: var(--rd-nk-cm-dot);
  transition: all .3s cubic-bezier(.34,1.4,.64,1);
}
.rd-cm-dot.done { background: var(--rd-nk-cm-dot-done); width: 14px; }
.rd-cm-dot.active {
  background: #34d399; width: 28px; box-shadow: 0 0 8px rgba(52,211,153,.6);
}
[data-theme="light"] .rd-cm-dot.active { background: #059669; }

.rd-cm-close {
  width: 38px; height: 38px; border-radius: 13px; cursor: pointer; font-size: 16px;
  background: var(--rd-nk-cm-close); border: 1px solid var(--rd-nk-cm-close-brd);
  color: var(--rd-nk-cm-close-c); display: flex; align-items: center; justify-content: center;
  transition: all .2s ease;
}
.rd-cm-close:hover {
  background: rgba(255,255,255,.1); color: var(--rd-nk-t1); transform: scale(1.08);
}
[data-theme="light"] .rd-cm-close:hover { background: rgba(10,31,18,.1); }

.rd-cm-main {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 32px 48px; position: relative; overflow: hidden;
  max-width: 820px; margin: 0 auto; width: 100%;
}
.rd-cm-ghost {
  position: absolute; font-family: 'Poppins', sans-serif;
  font-size: min(40vw,360px); font-weight: 900;
  color: var(--rd-nk-cm-ghost); line-height: 1;
  pointer-events: none; user-select: none;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  z-index: 0; transition: opacity .3s ease;
}
.rd-cm-step-lbl {
  font-family: 'Poppins', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 3px; color: var(--rd-nk-cm-lbl-c);
  margin-bottom: 20px; position: relative; z-index: 1;
  display: flex; align-items: center; gap: 9px;
}
.rd-cm-step-lbl::before,
.rd-cm-step-lbl::after {
  content: ''; display: block; width: 32px; height: 1px;
  background: linear-gradient(90deg,transparent,var(--rd-nk-cm-lbl-line));
}
.rd-cm-step-lbl::after { transform: scaleX(-1); }

.rd-cm-img-wrap {
  width: 100%; max-width: 420px; margin-bottom: 18px;
  position: relative; z-index: 1; border-radius: 16px; overflow: hidden;
}
.rd-cm-img {
  width: 100%; max-height: 200px; object-fit: cover; display: block; border-radius: 16px;
}
.rd-cm-img-wrap.hidden { display: none; }

.rd-cm-txt {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(15px,1.8vw,20px); font-weight: 400;
  line-height: 1.8; color: var(--rd-nk-cm-txt); text-align: center;
  max-width: 700px; position: relative; z-index: 1;
  transition: opacity .25s ease, transform .25s ease;
}
.rd-cm-txt.fading { opacity: 0; transform: translateY(8px); }

.rd-cm-timer {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 18px;
  padding: 8px 18px; background: var(--rd-nk-timer-bg);
  border: 1px solid var(--rd-nk-timer-brd); border-radius: 999px;
  font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 700;
  color: var(--rd-nk-timer-c); position: relative; z-index: 1;
}
.rd-cm-timer.hidden { display: none; }

/* Ingrédients dans Mode Cuisine */
.rd-cm-ingr {
  display: flex; gap: 9px; flex-wrap: wrap;
  justify-content: center; margin-top: 22px;
  position: relative; z-index: 1;
}
.rd-cm-ing-chip {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 13px 5px 5px;
  background: var(--rd-nk-chip-bg); border: 1px solid var(--rd-nk-chip-brd);
  border-radius: 999px;
  animation: rd-popIn .35s cubic-bezier(.34,1.6,.64,1) both;
}
@keyframes rd-popIn {
  from{opacity:0;transform:scale(.7)} to{opacity:1;transform:scale(1)}
}
.rd-cm-ing-av {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: var(--rd-nk-ing-av-bg); border: 1.5px solid rgba(52,211,153,.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; overflow: hidden;
}
[data-theme="light"] .rd-cm-ing-av { border-color: rgba(5,150,105,.18); }
.rd-cm-ing-av img { width: 100%; height: 100%; object-fit: cover; }
.rd-cm-ing-name {
  font-family: 'Poppins', sans-serif; font-size: 11px; font-weight: 700;
  color: var(--rd-nk-chip-t); white-space: nowrap;
}
.rd-cm-ing-qty {
  font-family: 'DM Sans', sans-serif; font-size: 10px;
  color: var(--rd-nk-chip-qty); white-space: nowrap; margin-left: 2px;
}

.rd-cm-mark {
  display: flex; align-items: center; gap: 8px; margin-top: 16px; padding: 10px 20px;
  background: var(--rd-nk-cm-mark-bg); border: 1px solid var(--rd-nk-cm-mark-brd);
  border-radius: 12px; font-family: 'Poppins', sans-serif;
  font-size: 11px; font-weight: 800; color: #34d399; cursor: pointer;
  text-transform: uppercase; letter-spacing: .5px; position: relative; z-index: 1;
  transition: all .2s ease;
}
[data-theme="light"] .rd-cm-mark { color: #059669; }
.rd-cm-mark:hover { background: rgba(52,211,153,.13); }
[data-theme="light"] .rd-cm-mark:hover { background: rgba(5,150,105,.1); }
.rd-cm-mark:disabled { opacity: .4; pointer-events: none; }

.rd-cm-nav {
  display: flex; align-items: center; justify-content: center;
  gap: 14px; padding: 16px 32px 32px; flex-shrink: 0;
}
.rd-cm-btn {
  display: flex; align-items: center; gap: 10px; padding: 14px 28px;
  border-radius: 17px; font-family: 'Poppins', sans-serif; font-size: 13px;
  font-weight: 800; cursor: pointer; transition: all .22s ease; white-space: nowrap;
}
.rd-cm-btn.prev {
  background: var(--rd-nk-cm-prev-bg); border: 1px solid var(--rd-nk-cm-prev-brd);
  color: var(--rd-nk-cm-prev-c);
}
.rd-cm-btn.prev:hover { color: var(--rd-nk-t1); background: rgba(255,255,255,.08); }
[data-theme="light"] .rd-cm-btn.prev:hover { background: rgba(10,31,18,.08); color: var(--rd-nk-t1); }
.rd-cm-btn.prev:disabled { opacity: .25; pointer-events: none; }
.rd-cm-btn.next {
  background: linear-gradient(135deg,rgba(52,211,153,.14),rgba(16,185,129,.07));
  border: 1px solid rgba(52,211,153,.38); color: #34d399;
  box-shadow: 0 4px 28px rgba(52,211,153,.1);
}
[data-theme="light"] .rd-cm-btn.next {
  background: rgba(5,150,105,.08); border-color: rgba(5,150,105,.3); color: #059669;
}
.rd-cm-btn.next:hover {
  box-shadow: 0 6px 36px rgba(52,211,153,.2); transform: translateY(-2px);
}
.rd-cm-btn.finish {
  background: linear-gradient(135deg,#f59e0b,#d97706);
  border: none; color: #fff; box-shadow: 0 4px 28px rgba(245,158,11,.25);
}
.rd-cm-btn.finish:hover { box-shadow: 0 6px 36px rgba(245,158,11,.4); transform: translateY(-2px); }

/* ── Confetti ─────────────────────────────────── */
.rd-confetti {
  position: fixed; border-radius: 2px; top: -20px;
  animation: rd-fall linear forwards; pointer-events: none; z-index: 1000;
}
@keyframes rd-fall {
  to { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

/* ── Mobile ───────────────────────────────────── */
@media (max-width: 767px) {
  .rd-prep-hd { flex-direction: column; align-items: flex-start; gap: 14px; }
  .rd-btn-cm { width: 100%; justify-content: center; }
  .rd-v-rail { display: none; }
  .rd-nk-nc { width: 40px; }
  .rd-nk-circ { width: 40px; height: 40px; }
  .rd-nk-circ-num { font-size: 13px; }
  .rd-nk-ghost { font-size: 90px; right: -4px; top: -12px; }
  .rd-nk-inner { padding: 16px 18px; border-radius: 18px; }
  .rd-nk-txt { font-size: 14px; }
  .rd-ingr-strip { gap: 7px; }
  .rd-ing-chip { padding: 4px 10px 4px 4px; gap: 6px; }
  .rd-ing-av { width: 28px; height: 28px; font-size: 14px; }
  .rd-ing-name { font-size: 10.5px; max-width: 90px; }
  .rd-ing-qty { display: none; }
  .rd-cm-main { padding: 18px 20px; }
  .rd-cm-txt { font-size: 16px; }
  .rd-cm-top { padding: 14px 16px; }
  .rd-cm-nav { padding: 14px 16px 28px; gap: 10px; }
  .rd-cm-btn { padding: 12px 16px; font-size: 12px; }
  .rd-cm-ingr { gap: 7px; }
  .rd-cm-ing-chip { padding: 4px 10px 4px 4px; }
}
