/* DINNER RESCUE */
#dinnerrescue-section { --dr-bg:#FAF7F2; --dr-card:#FFFDF9; --dr-text:#2C1810; --dr-muted:#6B5D52; --dr-faint:#9E9189; --dr-edge:#E8DFD2; --dr-gold:#B8943E; --dr-best:#6B7F5E; --dr-avoid:#A0614B; --dr-good:#B8943E; background:var(--dr-bg); color:var(--dr-text); padding:0; overflow:hidden; }
.dr-scroll { flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; min-height:0; }
.dr-body { max-width:520px; margin:0 auto; padding:32px 24px 48px; }
.dr-crumb { font-family:'Montserrat',sans-serif; font-size:0.55rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--dr-faint); margin-bottom:6px; }
.dr-title { font-family:'Playfair Display',Georgia,serif; font-size:1.6rem; font-weight:400; line-height:1.15; margin-bottom:4px; }
.dr-title em { color:var(--dr-gold); font-style:italic; }
.dr-subtitle { font-family:'Montserrat',sans-serif; font-size:0.75rem; color:var(--dr-faint); margin-bottom:16px; }
.dr-toggle { display:flex; gap:0; margin-bottom:16px; border-bottom:1px solid var(--dr-edge); }
.dr-toggle-btn { flex:1; padding:10px 0; background:none; border:none; border-bottom:2px solid transparent; color:var(--dr-faint); cursor:pointer; font-family:'Montserrat',sans-serif; font-size:0.68rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; }
.dr-toggle-btn.active { border-bottom-color:var(--dr-text); color:var(--dr-text); }
.dr-difficulty-area { margin-bottom:16px; }
.dr-difficulty-area .sd-wrap { display:flex; align-items:center; gap:10px; }
.dr-difficulty-area .sd-dots { display:flex; gap:4px; }
.dr-difficulty-area .sd-label { font-family:'Montserrat',sans-serif; font-size:0.6rem; color:var(--dr-faint); }
/* Dish card */
.dr-dish { padding:16px 18px; border-radius:10px; margin-bottom:16px; border:1px solid var(--dr-edge); background:var(--dr-card); text-align:center; display:flex; align-items:center; gap:6px; }
.dr-dish.variation { border-color:rgba(184,148,62,0.2); background:rgba(184,148,62,0.02); }
.dr-dish-nav { background:none; border:none; color:var(--dr-faint); font-size:1.25rem; cursor:pointer; padding:4px; flex-shrink:0; line-height:1; }
.dr-dish-content { flex:1; }
.dr-dish-phase { font-family:'Montserrat',sans-serif; font-size:0.55rem; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; color:var(--dr-faint); margin-bottom:4px; }
.dr-dish-name { font-family:'Playfair Display',Georgia,serif; font-size:1.05rem; font-weight:500; color:var(--dr-text); line-height:1.3; }
.dr-dish-old { font-family:'Playfair Display',Georgia,serif; font-size:0.72rem; color:var(--dr-faint); text-decoration:line-through; margin-bottom:4px; }
.dr-dish-arrow { font-family:'Montserrat',sans-serif; font-size:0.55rem; color:var(--dr-gold); font-weight:600; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:4px; }
.dr-dish-count { font-family:'Montserrat',sans-serif; font-size:0.55rem; color:var(--dr-faint); margin-top:6px; }
/* Wine bottles */
.dr-wines { display:flex; gap:6px; margin-bottom:6px; justify-content:center; flex-wrap:wrap; }
.dr-wine { display:flex; flex-direction:column; align-items:center; gap:4px; padding:12px 10px; border-radius:10px; cursor:pointer; border:2px solid var(--dr-edge); min-width:75px; flex:1 1 0; max-width:110px; transition:all 0.25s; background:var(--dr-card); }
.dr-wine.active { background:rgba(44,24,16,0.02); }
.dr-wine.best { border-color:var(--dr-best); }
.dr-wine.avoid { border-color:var(--dr-avoid); }
.dr-wine.good { border-color:var(--dr-good); }
.dr-wine-name { font-family:'Playfair Display',Georgia,serif; font-size:0.68rem; font-weight:600; color:var(--dr-text); text-align:center; line-height:1.2; }
.dr-wine-region { font-family:'Montserrat',sans-serif; font-size:0.48rem; color:var(--dr-faint); text-align:center; }
.dr-wine-verdict { font-family:'Montserrat',sans-serif; font-size:0.48rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; }
.dr-hint { font-family:'Crimson Text',Georgia,serif; font-size:0.72rem; color:var(--dr-faint); font-style:italic; text-align:center; margin-bottom:16px; }
/* Explanation */
.dr-expl { padding:14px 16px; border-radius:8px; margin-bottom:10px; }
.dr-expl.best { background:rgba(107,127,94,0.05); border:1px solid rgba(107,127,94,0.12); }
.dr-expl.avoid { background:rgba(160,97,75,0.04); border:1px solid rgba(160,97,75,0.08); }
.dr-expl.good { background:rgba(184,148,62,0.04); border:1px solid rgba(184,148,62,0.08); }
.dr-expl-header { display:flex; align-items:center; gap:6px; margin-bottom:5px; }
.dr-expl-dot { width:8px; height:8px; border-radius:50%; }
.dr-expl-label { font-family:'Montserrat',sans-serif; font-size:0.68rem; font-weight:600; }
.dr-expl-text { font-family:'Crimson Text',Georgia,serif; font-size:0.82rem; color:var(--dr-muted); line-height:1.7; }
/* Principle */
.dr-principle { padding:14px 16px; border-radius:8px; background:rgba(184,148,62,0.04); border:1px solid rgba(184,148,62,0.1); margin-bottom:14px; }
.dr-principle-label { font-family:'Montserrat',sans-serif; font-size:0.48rem; letter-spacing:0.1em; color:var(--dr-gold); text-transform:uppercase; font-weight:600; margin-bottom:6px; }
.dr-principle-text { font-family:'Crimson Text',Georgia,serif; font-size:0.82rem; color:var(--dr-muted); line-height:1.65; font-style:italic; }
/* Action */
.dr-action { width:100%; padding:12px; border-radius:8px; border:1px solid var(--dr-gold); background:transparent; color:var(--dr-gold); font-family:'Montserrat',sans-serif; font-size:0.82rem; font-weight:600; cursor:pointer; }
.dr-action-primary { background:var(--dr-text); color:var(--dr-bg); border-color:var(--dr-text); }
.dr-action:disabled { opacity:0.4; cursor:not-allowed; }
/* Quiz result */
.dr-quiz-bar { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.dr-quiz-bar span { font-family:'Montserrat',sans-serif; font-size:0.62rem; color:var(--dr-faint); }
.dr-quiz-score { color:var(--dr-gold) !important; font-weight:600; }
.dr-quiz-done { text-align:center; padding:40px 24px; }
.dr-quiz-done-score { font-family:'Playfair Display',Georgia,serif; font-size:2rem; margin-bottom:8px; }
.dr-quiz-done-msg { font-family:'Crimson Text',Georgia,serif; font-size:0.88rem; color:var(--dr-faint); margin-bottom:20px; }
@media(max-width:768px) { .dr-body { padding:24px 16px 40px; } .dr-wine { min-width:75px; padding:10px 6px; } }
