/* ============================================================================
   jekcms Recipe plugin — styled recipe card (works with any theme that has
   CSS custom properties; falls back to neutral defaults if not).
   ============================================================================ */

.rc-card {
    --rc-primary: var(--c-primary, #C45D3A);
    --rc-accent:  var(--c-accent, #7D8F69);
    --rc-surface: var(--c-surface, #fff);
    --rc-surface-alt: var(--c-surface-alt, #f7f3ee);
    --rc-warm: var(--c-warm-white, #FFFAF5);
    --rc-text: var(--c-text, #1A1714);
    --rc-muted: var(--c-text-muted, #6B5D4D);
    --rc-soft: var(--c-text-soft, #978778);
    --rc-border: var(--c-border, #EBE4DA);
    --rc-border-soft: var(--c-border-soft, #F3EDE3);

    display: block;
    background: var(--rc-warm);
    border: 1px solid var(--rc-border-soft);
    border-radius: 16px;
    padding: 36px 32px;
    margin: 48px 0;
    width: 100%;
    box-sizing: border-box;
    scroll-margin-top: 80px;
    box-shadow: 0 10px 40px -24px rgba(26, 23, 20, 0.18);
    font-family: inherit;
}
@media (max-width: 640px) { .rc-card { padding: 24px 20px; margin: 36px 0; border-radius: 12px; } }

/* ── Hero image inside card (16:9 action shot) ───────────────────────── */
.rc-hero-img {
    margin: -36px -32px 24px;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: 16px 16px 0 0;
}
.rc-hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 640px) {
    .rc-hero-img { margin: -24px -20px 20px; border-radius: 12px 12px 0 0; }
}

/* ── Header ─────────────────────────────────────────────────────────── */
.rc-header { text-align: center; padding-bottom: 24px; border-bottom: 1px dashed var(--rc-border); }
.rc-title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--rc-text);
    margin: 0 0 10px;
}
.rc-excerpt {
    color: var(--rc-muted);
    font-size: 1rem;
    line-height: 1.6;
    max-width: 52ch;
    margin: 0 auto 14px;
}
.rc-byline {
    display: flex;
    gap: 16px;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    color: var(--rc-soft);
    flex-wrap: wrap;
}
.rc-byline strong { color: var(--rc-text); font-weight: 600; }
.rc-print {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: transparent;
    border: 1px solid var(--rc-border);
    border-radius: 9999px;
    font-size: 12px;
    font-weight: 600;
    color: var(--rc-text);
    cursor: pointer;
    transition: all .2s ease;
    font-family: inherit;
}
.rc-print:hover { background: var(--rc-text); color: #fff; border-color: var(--rc-text); }

/* ── Meta chips ──────────────────────────────────────────────────────── */
.rc-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 4px;
    padding: 24px 0;
    border-bottom: 1px dashed var(--rc-border);
}
.rc-meta-cell {
    text-align: center;
    padding: 8px 4px;
    border-right: 1px dashed var(--rc-border);
}
.rc-meta-cell:last-child { border-right: none; }
@media (max-width: 640px) { .rc-meta-cell { border-right: none; } }
.rc-meta-label {
    display: block;
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--rc-soft);
    margin-bottom: 4px;
}
.rc-meta-value {
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--rc-text);
    letter-spacing: -0.01em;
}

/* ── Body layout ─────────────────────────────────────────────────────── */
.rc-body {
    display: grid;
    grid-template-columns: minmax(240px, 0.9fr) minmax(0, 1.2fr);
    gap: 40px;
    padding-top: 28px;
}
@media (max-width: 820px) { .rc-body { grid-template-columns: 1fr; gap: 32px; } }

.rc-section-title {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--rc-text);
    margin: 0 0 12px;
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.rc-section-title small {
    font-size: 12px;
    font-weight: 500;
    color: var(--rc-soft);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* ── Ingredients ─────────────────────────────────────────────────────── */
.rc-ingredients { padding-right: 12px; }
.rc-servings-note {
    font-size: 13px;
    color: var(--rc-muted);
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--rc-border-soft);
}
.rc-servings-note strong { color: var(--rc-primary); font-weight: 700; }
.rc-ingredient-list { list-style: none; padding: 0; margin: 0; }
.rc-ingredient {
    padding: 10px 0;
    border-bottom: 1px solid var(--rc-border-soft);
}
.rc-ingredient:last-child { border-bottom: none; }
.rc-ingredient label {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    cursor: pointer;
    font-size: 15px;
    line-height: 1.5;
    color: var(--rc-text);
}
.rc-check {
    flex-shrink: 0;
    appearance: none;
    width: 18px; height: 18px;
    border: 1.5px solid var(--rc-border);
    border-radius: 4px;
    background: var(--rc-surface);
    cursor: pointer;
    position: relative;
    margin-top: 2px;
    transition: all .2s ease;
}
.rc-check:checked {
    background: var(--rc-accent);
    border-color: var(--rc-accent);
}
.rc-check:checked::after {
    content: '';
    position: absolute;
    left: 5px; top: 1px;
    width: 5px; height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.rc-ingredient label:has(.rc-check:checked) .rc-ing-text {
    text-decoration: line-through;
    color: var(--rc-soft);
}
.rc-qty {
    font-weight: 700;
    color: var(--rc-primary);
    margin-right: 2px;
}
.rc-unit { margin-right: 3px; color: var(--rc-muted); }
.rc-note { color: var(--rc-soft); font-style: italic; }

/* ── Instructions ────────────────────────────────────────────────────── */
.rc-instructions { }
.rc-step-list { list-style: none; counter-reset: none; padding: 0; margin: 0; }
.rc-step {
    display: flex;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid var(--rc-border-soft);
}
.rc-step:last-child { border-bottom: none; }
.rc-step-num {
    flex-shrink: 0;
    width: 34px; height: 34px;
    border-radius: 50%;
    background: var(--rc-primary);
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 2px;
}
.rc-step-body {
    font-size: 15px;
    line-height: 1.65;
    color: var(--rc-text);
    padding-top: 4px;
}

/* ── Nutrition ───────────────────────────────────────────────────────── */
.rc-nutrition {
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px dashed var(--rc-border);
}
.rc-nutrition-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 4px;
    margin: 16px 0 12px;
}
.rc-nutrition-cell {
    text-align: center;
    padding: 12px 6px;
    background: var(--rc-surface);
    border: 1px solid var(--rc-border-soft);
    border-radius: 10px;
}
.rc-nutrition-value {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--rc-primary);
    letter-spacing: -0.01em;
}
.rc-nutrition-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--rc-soft);
    margin-top: 2px;
}
.rc-nutrition-note {
    font-size: 11px;
    color: var(--rc-soft);
    text-align: center;
    font-style: italic;
    margin: 0;
}

/* ── Footer / keywords ────────────────────────────────────────────── */
.rc-footer {
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px dashed var(--rc-border);
    font-size: 12px;
    color: var(--rc-soft);
}
.rc-kw-label { font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-right: 6px; }

/* ── FAQ (separate section) ───────────────────────────────────────── */
.recipe-faq { margin-top: 56px; }
.recipe-faq h2 {
    font-size: 1.5rem;
    letter-spacing: -0.02em;
    margin-bottom: 16px;
}
.recipe-faq .faq-item {
    border-bottom: 1px solid var(--rc-border-soft);
    padding: 16px 0;
}
.recipe-faq .faq-item summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 1rem;
    color: var(--rc-text);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.recipe-faq .faq-item summary::-webkit-details-marker { display: none; }
.recipe-faq .faq-item summary::after {
    content: '+';
    font-size: 1.5rem;
    color: var(--rc-soft);
    transition: transform .2s ease;
}
.recipe-faq .faq-item[open] summary::after { transform: rotate(45deg); }
.recipe-faq .faq-answer {
    margin-top: 10px;
    color: var(--rc-muted);
    line-height: 1.7;
    font-size: 15px;
}

/* ── Print ───────────────────────────────────────────────────────────── */
@media print {
    .rc-card { border: 1px solid #000; box-shadow: none; background: #fff; break-inside: avoid; }
    .rc-print { display: none; }
    .rc-check { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* Kicker replaces the old H2 title inside the card — avoids H1/H2 duplicate text */
.rc-kicker {
    display: inline-block;
    padding: 5px 14px;
    background: var(--rc-primary);
    color: #fff;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    border-radius: 9999px;
    margin-bottom: 14px;
}
