/* Shared recipe-page styles — used by all individual recipes in /recipes/ */

.rcp-hero { padding-block: calc(var(--nav-h) + clamp(24px, 4vw, 48px)) clamp(28px, 4vw, 40px); }
.rcp-hero-inner { max-width: 1180px; margin: 0 auto; padding-inline: var(--gutter); display: grid; grid-template-columns: 1fr; gap: clamp(24px, 4vw, 40px); align-items: start; }
@media (min-width: 768px) { .rcp-hero-inner { grid-template-columns: 1fr 1.1fr; } }

.rcp-breadcrumb { display: flex; gap: 6px; align-items: center; font-size: 12px; color: var(--text-soft); margin-block-end: 14px; flex-wrap: wrap; grid-column: 1 / -1; }
.rcp-breadcrumb a { color: var(--text-soft); text-decoration: none; }
.rcp-breadcrumb a:hover { color: var(--olive-dark); }
.rcp-breadcrumb svg { width: 10px; height: 10px; opacity: 0.5; }

.rcp-visual { aspect-ratio: 4/3; border-radius: 24px; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.rcp-visual-icon { width: 120px; height: 120px; color: rgba(255,255,255,0.55); }
.rcp-visual-gi { position: absolute; inset-block-end: 18px; inset-inline-end: 18px; background: rgba(255,255,255,0.96); padding: 12px 18px; border-radius: 16px; text-align: center; box-shadow: 0 4px 8px rgba(60,52,38,0.08), 0 2px 4px rgba(60,52,38,0.06); font-feature-settings: "tnum"; }
.rcp-visual-gi .num { font-size: 26px; font-weight: 700; line-height: 1; display: block; }
.rcp-visual-gi .lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; }
.rcp-visual-gi.low .num { color: var(--olive-dark); }
.rcp-visual-gi.mid .num { color: #8A6018; }
.rcp-visual-gi.high .num { color: var(--error); }
.rcp-visual-tags { position: absolute; inset-block-start: 18px; inset-inline-start: 18px; display: flex; gap: 6px; flex-wrap: wrap; }
.rcp-visual-tag { background: rgba(255,255,255,0.96); color: var(--olive-dark); font-size: 11px; font-weight: 600; padding: 5px 12px; border-radius: 999px; letter-spacing: 0.04em; box-shadow: 0 1px 2px rgba(60,52,38,0.05); }

.rcp-summary { display: flex; flex-direction: column; }
.rcp-meal-cat { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--olive-dark); margin-block-end: 10px; }
.rcp-title { font-size: clamp(28px, 4vw, 42px); font-weight: 600; line-height: 1.2; letter-spacing: -0.02em; margin-block-end: 14px; }
.rcp-lede { font-size: clamp(15px, 1.4vw, 17px); line-height: 1.75; color: var(--text-soft); margin-block-end: 22px; }

.rcp-quick-meta { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-block-end: 22px; }
@media (min-width: 520px) { .rcp-quick-meta { grid-template-columns: repeat(4, 1fr); } }
.rcp-quick-meta-item { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 16px 10px; text-align: center; }
.rcp-quick-meta-item .qm-icon { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; margin-block-end: 8px; }
.rcp-quick-meta-item .qm-icon svg { width: 18px; height: 18px; }
/* Recipe Ingredient + Nutrient Palette (Owner-locked colorful · variety-led system · D-023 · 2026-05-20)
   12 ingredient categories × 12 nutrient categories · each with distinct hue + tint pairing.
   Variety-led: each category recognized by COLOR first, icon-shape second.
   Owner decision (palette-comparison-2.html review): "colorful · variety-led" preferred over simplified 3-tone alternative.
   Documented in tokens.json landing-palette description · DO NOT audit as drift. */
.rcp-quick-meta-item.time .qm-icon { background: #E0EBED; color: #4A6E76; }
.rcp-quick-meta-item.servings .qm-icon { background: #EBE3F0; color: #6E4E80; }
.rcp-quick-meta-item.cuisine .qm-icon { background: #FBEEDA; color: #8A6018; }
.rcp-quick-meta-item.protein .qm-icon { background: #F7E8DE; color: #B8694B; }
.rcp-quick-meta-item.cal .qm-icon { background: #F4E4D4; color: #B8694B; }
.rcp-quick-meta-item.difficulty .qm-icon { background: #FDEEDE; color: #C4974A; }
.rcp-quick-meta-item .lbl { font-size: 11px; color: var(--text-soft); margin-block-end: 4px; }
.rcp-quick-meta-item .val { font-size: 16px; font-weight: 600; color: var(--text); font-feature-settings: "tnum"; line-height: 1.2; }
.rcp-quick-meta-item .val small { font-size: 11px; color: var(--text-soft); font-weight: 500; margin-inline-start: 2px; }

/* GI Balance Section (prominent) */
.rcp-balance { margin-block: 28px; }
.rcp-balance-title { font-size: 14px; font-weight: 600; color: var(--text); margin-block-end: 14px; display: flex; align-items: center; gap: 8px; }
.rcp-balance-title svg { width: 16px; height: 16px; color: var(--olive-dark); }
.rcp-balance-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-block-end: 12px; }
.rcp-balance-card { background: var(--olive-tint); border: 1px solid color-mix(in srgb, var(--olive) 30%, transparent); border-radius: 16px; padding: 20px 18px; text-align: center; position: relative; }
.rcp-balance-card-head { display: flex; align-items: center; justify-content: center; gap: 6px; font-size: 12px; color: var(--olive-dark); font-weight: 600; margin-block-end: 10px; }
.rcp-balance-card-head svg { width: 14px; height: 14px; }
.rcp-balance-card-num { font-size: clamp(28px, 4vw, 36px); font-weight: 700; color: var(--olive-dark); line-height: 1; font-feature-settings: "tnum"; margin-block-end: 8px; }
.rcp-balance-card-tag { display: inline-block; font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 999px; background: var(--white); color: var(--olive-dark); }
.rcp-balance-card-tag.mid { color: #8A6018; }
.rcp-balance-card-tag.high { color: var(--error); }
.rcp-balance-note { font-size: 12.5px; color: var(--text-soft); line-height: 1.7; text-align: center; }

/* Detailed nutrition list with icons */
.rcp-nutrition-list { background: var(--bg-soft); border-radius: 16px; padding: 22px 24px; margin-block: 24px; }
.rcp-nutrition-list-title { font-size: 13px; font-weight: 600; color: var(--text); margin-block-end: 14px; display: flex; align-items: center; gap: 8px; padding-block-end: 12px; border-block-end: 1px solid var(--border); }
.rcp-nutrition-list-title small { font-size: 11px; color: var(--text-soft); font-weight: 500; margin-inline-start: auto; }
.rcp-nutrition-list ul { list-style: none; padding: 0; margin: 0; }
.rcp-nutrition-list li { display: flex; align-items: center; gap: 12px; padding-block: 10px; border-block-end: 1px solid color-mix(in srgb, var(--border) 50%, transparent); }
.rcp-nutrition-list li:last-child { border: none; }
.rcp-nut-icon { width: 36px; height: 36px; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rcp-nut-icon svg { width: 18px; height: 18px; }
.rcp-nut-icon.cal { background: #F7E8DE; color: #B8694B; }
.rcp-nut-icon.protein { background: #E4DFF0; color: #6E4E80; }
.rcp-nut-icon.fat { background: #FBEEDA; color: #8A6018; }
.rcp-nut-icon.carb { background: #F4E4D4; color: #A88040; }
.rcp-nut-icon.fiber { background: #E8EFDC; color: #5A6E3D; }
.rcp-nut-icon.sodium { background: #DFE8EB; color: #4A6E76; }
.rcp-nut-label { flex: 1; font-size: 14px; color: var(--text); font-weight: 500; }
.rcp-nut-value { font-size: 15px; font-weight: 600; color: var(--text); font-feature-settings: "tnum"; }
.rcp-nut-value small { font-size: 11px; color: var(--text-soft); font-weight: 500; margin-inline-start: 3px; }

.rcp-action-row { display: flex; gap: 10px; flex-wrap: wrap; margin-block-start: auto; }
.rcp-action-primary { flex: 1; min-width: 200px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 22px; background: var(--olive-dark); color: var(--white); border-radius: 12px; font-size: 14.5px; font-weight: 600; text-decoration: none; transition: background 160ms var(--ease-out-quart), transform 160ms var(--ease-out-quart); }
.rcp-action-primary:hover { background: var(--olive-darker); transform: translateY(-1px); }
.rcp-action-primary svg { width: 16px; height: 16px; }
.rcp-action-secondary { display: inline-flex; align-items: center; gap: 6px; padding: 14px 16px; background: var(--white); color: var(--olive-dark); border: 1.5px solid var(--olive); border-radius: 12px; font: inherit; font-size: 13px; font-weight: 600; cursor: pointer; transition: background 160ms var(--ease-out-quart); }
.rcp-action-secondary:hover { background: var(--olive-tint); }
.rcp-action-secondary svg { width: 14px; height: 14px; }

.rcp-byline { display: flex; gap: 8px 14px; align-items: center; flex-wrap: wrap; padding-block-start: 16px; margin-block-start: 16px; border-block-start: 1px solid var(--border); font-size: 12.5px; color: var(--text-soft); }
.rcp-byline strong { color: var(--text); font-weight: 600; }
.rcp-byline svg { width: 14px; height: 14px; color: var(--olive-dark); }

/* ═══ BODY (2-col: ingredients sidebar + steps main) ═══ */
.rcp-body { background: var(--white); padding-block: clamp(40px, 5vw, 64px); }
.rcp-body-layout { max-width: 1180px; margin: 0 auto; padding-inline: var(--gutter); display: grid; grid-template-columns: 1fr; gap: clamp(28px, 4vw, 48px); align-items: start; }
@media (min-width: 900px) { .rcp-body-layout { grid-template-columns: 280px 1fr; } }

.rcp-sidebar { background: var(--cream); border-radius: 16px; padding: 24px; min-width: 0; }
@media (min-width: 900px) { .rcp-sidebar { position: sticky; top: calc(var(--nav-h) + 20px); } }
.rcp-sidebar h3 { font-size: 14px; font-weight: 600; color: var(--olive-dark); text-transform: uppercase; letter-spacing: 0.08em; margin-block-end: 14px; padding-block-end: 10px; border-block-end: 1px solid var(--border); }
.rcp-ingredients { list-style: none; padding: 0; margin: 0; }
.rcp-ingredients li { display: flex; align-items: center; gap: 12px; padding-block: 10px; font-size: 14px; line-height: 1.5; color: var(--text); border-block-end: 1px solid color-mix(in srgb, var(--border) 60%, transparent); }
.rcp-ingredients li:last-child { border: none; }
.rcp-ingredients strong { font-weight: 600; color: var(--text); font-feature-settings: "tnum"; }
/* Quiet ingredient link · مكوّن يقود لصفحة محتوى المكوّن · خطّ سفليّ رفيع فقط */
.rcp-ing-link { color: inherit; text-decoration: none; border-block-end: 1px solid var(--border-strong); transition: border-color 160ms var(--ease-out-quart); }
.rcp-ing-link:hover { border-block-end-color: var(--olive-dark); }
.rcp-ing-icon { flex-shrink: 0; width: 36px; height: 36px; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; }
.rcp-ing-icon svg { width: 20px; height: 20px; }
.rcp-ing-icon.protein { background: #F7E8DE; color: #B8694B; }
.rcp-ing-icon.grain { background: #F5EFE0; color: #A88040; }
.rcp-ing-icon.veg { background: #E8EFDC; color: #5A6E3D; }
.rcp-ing-icon.spice { background: #F4E4D4; color: #8A6018; }
.rcp-ing-icon.herb { background: #E0EBD4; color: #557A3A; }
.rcp-ing-icon.dairy { background: #F0EFEB; color: #6E6E73; }
.rcp-ing-icon.oil { background: #ECE8D8; color: #729A4B; }
.rcp-ing-icon.fruit { background: #FBEEDA; color: #8A6018; }
.rcp-ing-icon.nut { background: #EAE0D4; color: #6B4423; }
.rcp-ing-icon.fish { background: #DFE8EB; color: #4A6E76; }
.rcp-ing-icon.water { background: #DCE7EC; color: #5F7385; }
.rcp-ing-icon.other { background: #F0F0EE; color: #6E6E73; }
.rcp-sidebar-cta { display: block; margin-block-start: 16px; padding: 12px 14px; background: var(--white); border: 1px solid var(--border-strong); border-radius: 10px; text-align: center; font-size: 13px; color: var(--olive-dark); font-weight: 600; text-decoration: none; transition: border-color 160ms var(--ease-out-quart); }
.rcp-sidebar-cta:hover { border-color: var(--olive); }

/* min-width:0 lets the 1fr grid track shrink below its content's min-content.
   Without it, the min-width:560px subs/scaling tables pin the column at 560px and
   blow the whole layout past narrow viewports (no inline-start padding in RTL). */
.rcp-content { max-width: none; min-width: 0; }
/* Quiet Luxury · h2 uses olive-darker color directly · no side-stripe chrome (D-023 · 2026-05-20) */
.rcp-content h2 { font-size: clamp(22px, 2.6vw, 28px); font-weight: 600; line-height: 1.3; margin-block: 36px 14px; color: var(--olive-darker); scroll-margin-top: calc(var(--nav-h) + 20px); }
.rcp-content h2:first-child { margin-block-start: 0; }
.rcp-content h3 { font-size: 18px; font-weight: 600; margin-block: 22px 10px; }
.rcp-content p { font-size: 15.5px; line-height: 1.9; color: var(--text); margin-block-end: 16px; }
.rcp-content ul, .rcp-content ol { padding-inline-start: 24px; margin-block-end: 16px; }
.rcp-content li { font-size: 15px; line-height: 1.85; color: var(--text); margin-block-end: 6px; }
.rcp-content strong { color: var(--text); font-weight: 600; }
.rcp-content a { color: var(--olive-dark); font-weight: 600; text-decoration: none; border-block-end: 1px solid var(--olive); }
.rcp-content a:hover { background: var(--olive-tint); }

/* Steps as numbered cards */
.rcp-steps { list-style: none; padding: 0; margin: 0; counter-reset: step; }
.rcp-steps > li { counter-increment: step; background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 20px 22px; padding-inline-start: 78px; margin-block-end: 12px; position: relative; }
.rcp-steps > li::before { content: counter(step, arabic-indic); position: absolute; inset-inline-start: 20px; top: 18px; width: 36px; height: 36px; background: var(--olive-dark); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: 700; font-feature-settings: "tnum"; }
.rcp-steps .step-title { font-size: 15px; font-weight: 600; margin-block-end: 6px; color: var(--text); }
.rcp-steps .step-desc { font-size: 14px; line-height: 1.7; color: var(--text-soft); margin: 0; }
.rcp-steps .step-time { display: inline-block; margin-block-start: 8px; font-size: 11px; font-weight: 600; padding: 3px 9px; background: var(--olive-tint); color: var(--olive-dark); border-radius: 999px; font-feature-settings: "tnum"; }
/* step photos (only steps that carry a .step-img switch to the media layout; the other recipes stay untouched) */
.rcp-steps > li:has(.step-img) { display: flex; align-items: flex-start; gap: 22px; }
.rcp-steps > li > .step-body { flex: 1 1 auto; min-width: 0; }
.rcp-steps > li > .step-img { flex: 0 0 224px; width: 224px; height: 168px; object-fit: cover; border-radius: 12px; border: 1px solid var(--border); }
@media (max-width: 640px) {
  .rcp-steps > li:has(.step-img) { flex-direction: column; }
  .rcp-steps > li > .step-img { flex: none; width: 100%; height: auto; aspect-ratio: 4 / 3; order: -1; margin-block-end: 12px; }
}
/* ingredients flat-lay photo (top of sidebar; only rendered on recipes that ship one) */
.rcp-ing-photo { display: block; width: 100%; height: auto; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 14px; border: 1px solid var(--border); margin-block-end: 18px; }

/* cook-mode step photo */
.cook-mode-step-img { width: min(440px, 82%); aspect-ratio: 4 / 3; object-fit: cover; border-radius: 16px; border: 1px solid var(--border); }
.cook-mode-step-img[hidden] { display: none; }

/* Nutrition table */
.rcp-nutrition { background: var(--bg-soft); border-radius: 16px; padding: 22px 24px; margin-block: 24px; }
.rcp-nutrition-title { font-size: 13px; font-weight: 600; color: var(--olive-dark); text-transform: uppercase; letter-spacing: 0.08em; margin-block-end: 14px; display: flex; align-items: center; gap: 8px; }
.rcp-nutrition-title svg { width: 16px; height: 16px; flex-shrink: 0; }
.rcp-nutrition-title small { font-size: 11px; color: var(--text-soft); font-weight: 500; text-transform: none; letter-spacing: 0; margin-inline-start: auto; }
.rcp-nutrition-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (min-width: 520px) { .rcp-nutrition-grid { grid-template-columns: repeat(4, 1fr); } }
.rcp-nutrition-item { background: var(--white); border-radius: 10px; padding: 12px 14px; text-align: center; }
.rcp-nutrition-item .val { font-size: 18px; font-weight: 700; color: var(--text); font-feature-settings: "tnum"; line-height: 1; }
.rcp-nutrition-item .val small { font-size: 11px; color: var(--text-soft); font-weight: 500; margin-inline-start: 2px; }
.rcp-nutrition-item .lbl { font-size: 10.5px; color: var(--text-soft); margin-block-start: 4px; text-transform: uppercase; letter-spacing: 0.05em; }

/* Tip box */
.rcp-tip { background: var(--olive-tint); border-block-start: 3px solid var(--olive); border-radius: 12px; padding: 18px 22px; margin-block: 20px; }
.rcp-tip-title { font-size: 12px; font-weight: 600; color: var(--olive-dark); text-transform: uppercase; letter-spacing: 0.08em; margin-block-end: 8px; display: inline-flex; align-items: center; gap: 6px; }
.rcp-tip-title svg { width: 14px; height: 14px; flex-shrink: 0; }
.rcp-tip p { font-size: 14px; line-height: 1.75; color: var(--text); margin: 0; }
.rcp-tip strong { color: var(--olive-dark); }

/* FAQ */
.rcp-faq { margin-block: 28px; }
.rcp-faq details { background: var(--white); border: 1px solid var(--border); border-radius: 12px; padding: 16px 20px; margin-block-end: 8px; }
.rcp-faq details[open] { background: var(--bg-soft); }
.rcp-faq summary { font-size: 14.5px; font-weight: 600; color: var(--text); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.rcp-faq summary::-webkit-details-marker { display: none; }
.rcp-faq summary::after { content: '+'; font-size: 22px; color: var(--olive-dark); transition: transform 200ms; }
.rcp-faq details[open] summary::after { transform: rotate(45deg); }
.rcp-faq .faq-a { font-size: 14px; line-height: 1.75; color: var(--text-soft); margin-block-start: 10px; padding-block-start: 10px; border-block-start: 1px solid var(--border); }

/* CTA Box */
.rcp-cta-box { background: var(--olive-dark); color: var(--white); border-radius: 20px; padding: clamp(28px, 4vw, 36px); margin-block: 32px; text-align: center; }
.rcp-cta-box h3 { font-size: clamp(20px, 2.4vw, 24px); font-weight: 600; line-height: 1.3; margin-block-end: 8px; color: var(--white); }
.rcp-cta-box h3::before { display: none; }
.rcp-cta-box p { font-size: 14.5px; line-height: 1.7; color: rgba(255,255,255,0.85); margin-block-end: 20px; max-width: 420px; margin-inline: auto; }
.rcp-cta-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.rcp-cta-box .btn-w { background: var(--white); color: var(--olive-dark); padding: 12px 22px; border-radius: 12px; font: inherit; font-size: 14px; font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.rcp-cta-box .btn-gw { background: transparent; color: var(--white); border: 1.5px solid rgba(255,255,255,0.6); padding: 12px 22px; border-radius: 12px; font: inherit; font-size: 14px; font-weight: 600; text-decoration: none; cursor: pointer; }
.rcp-cta-box .btn-gw:hover { background: rgba(255,255,255,0.1); border-color: var(--white); }

/* Related recipes */
.rcp-related { background: var(--bg-section); padding-block: clamp(36px, 4vw, 56px); }
.rcp-related-inner { max-width: 1180px; margin: 0 auto; padding-inline: var(--gutter); }
.rcp-related h2 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 600; margin-block-end: 20px; }
.rcp-related-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px) { .rcp-related-grid { grid-template-columns: repeat(3, 1fr); } }
.rcp-related-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; text-decoration: none; color: var(--text); display: flex; flex-direction: column; transition: transform 200ms var(--ease-out-quart), box-shadow 200ms var(--ease-out-quart), border-color 200ms var(--ease-out-quart); }
.rcp-related-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--olive); }
.rcp-related-card .img { aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.55); position: relative; background: var(--bg-section); overflow: hidden; }
.rcp-related-card .img svg { width: 36px; height: 36px; }
.rcp-related-card .img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rcp-related-card .gi-mini { position: absolute; inset-block-start: 8px; inset-inline-start: 8px; background: rgba(255,255,255,0.95); color: var(--olive-dark); font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 999px; font-feature-settings: "tnum"; }
.rcp-related-card .body { padding: 14px 16px; }
.rcp-related-card .meal { font-size: 10px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--olive-dark); margin-block-end: 4px; }
.rcp-related-card h3 { font-size: 14px; font-weight: 600; line-height: 1.4; }

/* ═══════════════════════════════════════════════════════════════════
 * V5 · GI Widget — Glycemic Balance card (permanent in all recipes)
 * uses brand tokens only · no off-palette hex
 * ═══════════════════════════════════════════════════════════════════ */
.rcp-gi-widget { background: var(--white); border: 1px solid var(--border); border-radius: 16px; padding: 22px 22px 20px; margin-block-end: 18px; box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 24px rgba(46,90,24,0.04); }
.rcp-gi-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-block-end: 16px; }
.rcp-gi-header h3 { font-size: 15px; font-weight: 600; color: var(--text); margin: 0; letter-spacing: -0.005em; }
.rcp-gi-info { position: relative; }
.rcp-gi-info summary { list-style: none; cursor: pointer; width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: var(--text-soft); transition: color 160ms, background 160ms; background: var(--bg-soft); }
.rcp-gi-info summary::-webkit-details-marker { display: none; }
.rcp-gi-info summary:hover { color: var(--olive-dark); background: var(--olive-tint); }
.rcp-gi-info summary svg { width: 14px; height: 14px; }
.rcp-gi-info[open] p { font-size: 12.5px; line-height: 1.7; color: var(--text-soft); margin: 12px 0 0; padding: 12px 14px; background: var(--bg-soft); border-radius: 10px; border-inline-start: 3px solid var(--olive); }

.rcp-gi-indices { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-block-end: 14px; }
.rcp-gi-card { padding: 16px 12px 14px; border-radius: 14px; text-align: center; position: relative; border: 1px solid transparent; }
.rcp-gi-card.low { background: var(--olive-tint); border-color: rgba(106, 178, 64, 0.30); }
.rcp-gi-card.medium { background: rgba(229, 165, 56, 0.10); border-color: rgba(229, 165, 56, 0.35); }
.rcp-gi-card.high { background: rgba(184, 58, 58, 0.08); border-color: rgba(184, 58, 58, 0.30); }
.rcp-gi-card-icon { width: 28px; height: 28px; margin: 0 auto 6px; display: flex; align-items: center; justify-content: center; }
.rcp-gi-card-icon svg { width: 20px; height: 20px; }
.rcp-gi-card.low .rcp-gi-card-icon { color: var(--olive-dark); }
.rcp-gi-card.medium .rcp-gi-card-icon { color: #856404; }
.rcp-gi-card.high .rcp-gi-card-icon { color: var(--error); }
.rcp-gi-card-label { font-size: 12px; color: var(--text-soft); margin-block-end: 4px; }
.rcp-gi-card-value { font-size: 28px; font-weight: 700; color: var(--text); line-height: 1; font-feature-settings: "tnum"; }
.rcp-gi-badge { display: inline-block; font-size: 11px; font-weight: 600; padding: 3px 12px; border-radius: 999px; margin-block-start: 8px; letter-spacing: 0.02em; }
.rcp-gi-card.low .rcp-gi-badge { background: var(--olive-dark); color: var(--white); }
.rcp-gi-card.medium .rcp-gi-badge { background: var(--warning, #E5A538); color: var(--white); }
.rcp-gi-card.high .rcp-gi-badge { background: var(--error, #B83A3A); color: var(--white); }

.rcp-gi-meaning { font-size: 11.5px; color: var(--text-soft); line-height: 1.7; margin: 0 0 16px; text-align: center; padding-inline: 4px; }
.rcp-gi-section { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; color: var(--olive-darker); text-transform: uppercase; padding-block-start: 14px; border-block-start: 1px solid var(--border); margin-block-end: 12px; }
.rcp-gi-macros { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.rcp-gi-macros li { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--bg-soft); border-radius: 10px; transition: background 160ms; }
.rcp-gi-macros li:hover { background: var(--cream); }
.rcp-gi-macros .ico { width: 32px; height: 32px; border-radius: 50%; background: var(--olive-tint); color: var(--olive-dark); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rcp-gi-macros .ico svg { width: 16px; height: 16px; }
.rcp-gi-macros .lbl { flex: 1; font-size: 13.5px; color: var(--text); }
.rcp-gi-macros .val { font-size: 16px; font-weight: 700; color: var(--text); font-feature-settings: "tnum"; }
.rcp-gi-macros .val small { font-size: 11px; font-weight: 500; color: var(--text-soft); margin-inline-start: 3px; }
.rcp-gi-full { display: flex; align-items: center; justify-content: center; gap: 6px; margin-block-start: 14px; font-size: 13px; font-weight: 600; color: var(--olive-dark); text-decoration: none; padding: 11px; background: var(--bg-soft); border-radius: 10px; transition: background 160ms, color 160ms; }
.rcp-gi-full:hover { background: var(--olive-darker); color: var(--white); }
.rcp-gi-full::after { content: "←"; font-size: 14px; transition: transform 160ms; }
.rcp-gi-full:hover::after { transform: translateX(-3px); }

/* ═══════════════════════════════════════════════════════════════════
 * V5 · Jump Bar — improved hierarchy + harmonious colors
 * the primary action (steps) stands out; secondary actions ride along
 * ═══════════════════════════════════════════════════════════════════ */
.rcp-jump-bar { background: linear-gradient(135deg, var(--cream) 0%, var(--white) 100%); border: 1px solid var(--border); padding: 14px 18px; }
.rcp-jump-bar .jump-label { color: var(--text); font-weight: 700; font-size: 12.5px; }
.rcp-jump-bar .jump-link { background: var(--white); border: 1px solid var(--border); color: var(--text); font-weight: 500; padding: 9px 14px; transition: all 200ms var(--ease-out-quart); }
.rcp-jump-bar .jump-link:hover { background: var(--bg-soft); border-color: var(--olive); color: var(--olive-darker); transform: translateY(-1px); box-shadow: 0 2px 6px rgba(46, 90, 24, 0.10); }
.rcp-jump-bar .jump-link svg { color: var(--olive-dark); }
.rcp-jump-bar .jump-link.jump-primary { background: var(--olive-darker); color: var(--white); border-color: var(--olive-darker); font-weight: 600; }
.rcp-jump-bar .jump-link.jump-primary svg { color: var(--white); }
.rcp-jump-bar .jump-link.jump-primary:hover { background: var(--olive-dark); box-shadow: 0 4px 10px rgba(46, 90, 24, 0.25); transform: translateY(-1px); }

/* ═══════════════════════════════════════════════════════════════════
 * V5 · 3-way table column widths (uses colgroup pattern)
 * ═══════════════════════════════════════════════════════════════════ */
.rcp-types-table table { table-layout: auto; }
.rcp-types-table th:first-child, .rcp-types-table td:first-child { width: 18%; min-width: 130px; }
.rcp-types-table th:last-child, .rcp-types-table td:last-child { width: 28%; min-width: 220px; line-height: 1.6; }

/* V5 · Substitutions intro note (when subs need context disambiguation) */
.rcp-subs-note { font-size: 13.5px; line-height: 1.85; color: var(--text-soft); margin-block: 12px 14px; padding: 12px 16px; background: var(--bg-soft); border-inline-start: 3px solid var(--olive); border-radius: 8px; }

/* ═══════════════════════════════════════════════════════════════════
 * Wave 1 — Troubleshoot · Storage · Substitutions · Scaling
 * Promoted from model recipes (hejazi-maasoub-banana · falafel-shamia ·
 * saudi-liver-hashi) to shared so all V3 recipes inherit.
 * ═══════════════════════════════════════════════════════════════════ */

/* Troubleshoot — collapsible problem/solution accordion */
.rcp-troubleshoot { display: grid; gap: 10px; margin-block: 20px; }
.rcp-troubleshoot details { background: var(--white); border: 1px solid var(--border); border-radius: 12px; padding: 0; overflow: hidden; transition: border-color 200ms; }
.rcp-troubleshoot details:hover { border-color: var(--olive); }
.rcp-troubleshoot summary { padding: 16px 20px; font-size: 14.5px; font-weight: 600; color: var(--olive-darker); cursor: pointer; list-style: none; display: flex; align-items: center; gap: 10px; }
.rcp-troubleshoot summary::-webkit-details-marker { display: none; }
.rcp-troubleshoot summary::before { content: ""; width: 8px; height: 8px; border-inline-end: 2px solid var(--olive); border-block-end: 2px solid var(--olive); transform: rotate(-45deg); transition: transform 200ms; flex-shrink: 0; }
.rcp-troubleshoot details[open] summary::before { transform: rotate(45deg); }
.rcp-troubleshoot details p { padding: 0 20px 16px; margin: 0; font-size: 14px; line-height: 1.85; color: var(--text); }

/* Storage — 4-card grid (fridge / freezer / prep-ahead / serve-reheat) */
.rcp-storage-grid { display: grid; gap: 14px; margin-block: 20px; grid-template-columns: 1fr; }
@media (min-width: 720px) { .rcp-storage-grid { grid-template-columns: repeat(2, 1fr); } }
.rcp-storage-item { background: var(--bg-soft); border: 1px solid var(--border); border-radius: 14px; padding: 18px 20px; }
.rcp-storage-icon { width: 36px; height: 36px; border-radius: 10px; background: var(--olive-tint); color: var(--olive-dark); display: inline-flex; align-items: center; justify-content: center; margin-block-end: 10px; }
.rcp-storage-icon svg { width: 18px; height: 18px; }
.rcp-storage-item h4 { font-size: 14.5px; font-weight: 600; color: var(--olive-darker); margin: 0 0 6px; }
.rcp-storage-item p { font-size: 13.5px; line-height: 1.8; margin: 0 0 6px; color: var(--text); }
.rcp-storage-item p:last-child { margin: 0; }
.rcp-storage-item strong { color: var(--olive-darker); }

/* Substitutions + Scaling — shared table styling, featured row for scaling */
.rcp-subs, .rcp-scaling { margin-block: 20px; overflow-x: auto; border-radius: 16px; box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 24px rgba(46,90,24,0.05); }
.rcp-subs table, .rcp-scaling table { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid var(--border); border-radius: 16px; overflow: hidden; font-size: 14px; min-width: 560px; }
.rcp-subs th, .rcp-subs td, .rcp-scaling th, .rcp-scaling td { padding: 14px 16px; text-align: start; border-block-end: 1px solid var(--border); vertical-align: middle; }
.rcp-subs thead th, .rcp-scaling thead th { background: var(--olive-darker); color: var(--white); font-weight: 600; font-size: 12.5px; letter-spacing: 0.04em; padding-block: 12px; border-block-end: none; }
.rcp-subs thead th:first-child, .rcp-scaling thead th:first-child { border-start-start-radius: 16px; }
.rcp-subs thead th:last-child, .rcp-scaling thead th:last-child { border-start-end-radius: 16px; }
.rcp-subs tbody tr:last-child td, .rcp-scaling tbody tr:last-child td { border-block-end: none; }
.rcp-scaling tr.featured { background: var(--olive-tint); }
.rcp-scaling tr.featured td:first-child { border-inline-start: 3px solid var(--olive); font-weight: 700; }
.rcp-scaling-note { font-size: 13px; color: var(--text-soft); margin: 12px 4px 0; line-height: 1.8; font-style: italic; }

/* Allergens — Gulf GSO 9/2013 mandatory allergen declaration */
.rcp-allergen { background: color-mix(in srgb, var(--warning) 10%, var(--white)); border: 1px solid var(--warning); border-inline-start: 4px solid var(--warning); border-radius: 14px; padding: 18px 22px; margin-block: 24px; }
.rcp-allergen-header { display: flex; align-items: center; gap: 10px; font-size: 14.5px; font-weight: 600; color: var(--warning-text); margin-block-end: 12px; }
.rcp-allergen-header svg { width: 20px; height: 20px; flex-shrink: 0; color: var(--warning-text); }
.rcp-allergen-list { list-style: none; padding: 0; margin: 0 0 10px; display: flex; flex-direction: column; gap: 6px; }
.rcp-allergen-list li { font-size: 14px; line-height: 1.85; color: var(--text); }
.rcp-allergen-list strong { color: var(--warning-text); }
.rcp-allergen-note { font-size: 12.5px; color: var(--text-soft); margin: 8px 0 0; line-height: 1.7; font-style: italic; padding-block-start: 8px; border-block-start: 1px dashed var(--warning); }

/* Sources — collapsible numbered citation block at recipe footer */
.rcp-sources { margin-block: 32px 16px; padding: 18px 22px; background: var(--bg-soft); border: 1px solid var(--border); border-radius: 14px; border-inline-start: 3px solid var(--olive); }
.rcp-sources h2 { font-size: 18px; color: var(--olive-darker); margin: 0 0 12px; }
.rcp-sources-details summary { display: flex; align-items: center; gap: 10px; cursor: pointer; list-style: none; font-size: 18px; font-weight: 600; color: var(--olive-darker); }
.rcp-sources-details summary::-webkit-details-marker { display: none; }
.rcp-sources-details summary::before { content: ""; width: 8px; height: 8px; border-inline-end: 2px solid var(--olive); border-block-end: 2px solid var(--olive); transform: rotate(-45deg); transition: transform 200ms; flex-shrink: 0; }
.rcp-sources-details[open] summary::before { transform: rotate(45deg); }
.rcp-sources-body { padding-block-start: 14px; }
.rcp-sources-list { font-size: 13px; line-height: 1.85; color: var(--text); padding-inline-start: 22px; margin: 0 0 10px; }
.rcp-sources-list li { margin-block-end: 8px; }
.rcp-sources-list a { color: var(--olive-dark); text-decoration: underline; text-underline-offset: 2px; }
.rcp-sources-list a:hover { color: var(--olive-darker); }
.rcp-sources-note { font-size: 12.5px; color: var(--text-soft); line-height: 1.8; margin: 10px 0 0; font-style: italic; }
sup a, .rcp-content sup a { font-size: 11px; font-weight: 600; color: var(--olive-dark); text-decoration: none; padding: 0 2px; }
sup a:hover, .rcp-content sup a:hover { color: var(--olive-darker); }

/* ═══════════════════════════════════════════════════════════════════
 * V6 · Layout match — sticky sidebar + GI widget in hero summary
 * eliminates gaps from short sidebar vs long main content
 * ═══════════════════════════════════════════════════════════════════ */
.rcp-summary > .rcp-gi-widget { margin-block-start: 18px; margin-block-end: 0; }
@media (min-width: 900px) {
  .rcp-sidebar { position: sticky; inset-block-start: calc(var(--nav-h) + 16px); align-self: start; max-height: calc(100vh - var(--nav-h) - 32px); overflow-y: auto; }
  .rcp-sidebar::-webkit-scrollbar { width: 6px; }
  .rcp-sidebar::-webkit-scrollbar-track { background: transparent; }
  .rcp-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
  .rcp-sidebar::-webkit-scrollbar-thumb:hover { background: var(--olive); }
}

/* ═══ MOBILE · responsive fixes ═══ */

/* Action row — primary fills its own row on small phones */
@media (max-width: 520px) {
  .rcp-action-primary { flex: 1 1 100%; min-width: 0; }
  .rcp-action-row { gap: 8px; }
}

/* Quick meta — ensure 2×2 fits on all phone widths */
@media (max-width: 400px) {
  .rcp-quick-meta-item { padding: 12px 8px; }
  .rcp-quick-meta-item .val { font-size: 14px; }
  .rcp-quick-meta-item .qm-icon { width: 28px; height: 28px; }
  .rcp-quick-meta-item .qm-icon svg { width: 14px; height: 14px; }
}

/* Steps — slightly tighter counter on very narrow screens */
@media (max-width: 400px) {
  .rcp-steps > li { padding-block: 14px; padding-inline-end: 14px; padding-inline-start: 58px; }
  .rcp-steps > li::before { width: 30px; height: 30px; font-size: 14px; inset-inline-start: 14px; top: 14px; }
}

/* Related grid — single card per row on narrow phones */
@media (max-width: 400px) {
  .rcp-related-grid { grid-template-columns: 1fr; }
}

/* Hero title — tighten clamp for very small screens */
@media (max-width: 380px) {
  .rcp-title { font-size: clamp(24px, 6vw, 32px); }
  .rcp-lede { font-size: 14px; }
}
