/* ══════════════════════════════════════════
   MODALS — Recipe detail modal, add recipe modal, reviews
   ══════════════════════════════════════════ */

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);z-index:200;display:none;align-items:center;justify-content:center;padding:40px}
.modal-overlay.open{display:flex}
.modal{background:var(--warm-white);max-width:700px;width:100%;max-height:88vh;overflow-y:auto;position:relative;animation:fadeUp .35s ease forwards}
.modal-art{height:260px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.modal-art-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.modal-art-emoji{font-size:90px;z-index:3;filter:drop-shadow(0 6px 20px rgba(0,0,0,.3));line-height:1;position:relative}
.modal-art-bg{position:absolute;inset:0;z-index:0}
.modal-art-circle{position:absolute;border-radius:50%;opacity:.15}
.modal-art-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,12,.55) 0%,transparent 55%);z-index:2}
.modal-body{padding:32px}
.modal-category{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta);font-weight:500;margin-bottom:6px}
.modal-title{font-family:'Playfair Display',serif;font-size:32px;font-weight:900;margin-bottom:10px}
.modal-rating-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.modal-stars{display:flex;gap:3px}
.modal-star{font-size:20px;cursor:pointer;color:#ddd;transition:color .15s}
.modal-star.filled{color:var(--gold)}
.modal-rating-count{font-size:12px;color:var(--ink-light)}
.modal-meta{display:flex;gap:16px;font-size:13px;color:var(--ink-light);padding:13px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:22px;flex-wrap:wrap;align-items:center}
.modal h4{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;margin-bottom:10px;margin-top:20px}
.modal ul,.modal ol{padding-left:20px;font-size:14px;line-height:2.1;color:var(--ink-light)}
.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin:12px 0}
.nutrition-cell{background:var(--cream);padding:12px;text-align:center}
.nutrition-val{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--ink);line-height:1}
.nutrition-key{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-light);margin-top:3px}
.scaler{display:flex;align-items:center;gap:8px;margin-left:auto}
.scaler label{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-light)}
.scaler-controls{display:flex;align-items:center}
.scaler-btn{width:27px;height:27px;border:1.5px solid var(--border);background:transparent;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--ink)}
.scaler-btn:hover{background:var(--terracotta);border-color:var(--terracotta);color:white}
#serving-display{width:32px;height:27px;border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);border-left:none;border-right:none;text-align:center;font-size:13px;font-family:'DM Sans',sans-serif;background:transparent;color:var(--ink);outline:none}
.modal-actions{display:flex;gap:8px;margin-top:24px;flex-wrap:wrap}
.action-btn{padding:9px 16px;border:1.5px solid var(--border);background:transparent;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:5px;color:var(--ink-light);transition:all .2s}
.action-btn:hover{border-color:var(--terracotta);color:var(--terracotta)}
.action-btn.fav-action.active{background:var(--terracotta);border-color:var(--terracotta);color:white}
.close-btn{position:absolute;top:13px;right:13px;width:32px;height:32px;background:rgba(30,26,22,.6);border:none;color:white;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}
.close-btn:hover{background:rgba(30,26,22,.9)}

/* ── REVIEWS ── */
.reviews-section{margin-top:28px;padding-top:22px;border-top:2px solid var(--border)}
.reviews-heading{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;margin-bottom:18px;display:flex;align-items:baseline;gap:10px}
.reviews-heading span{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:var(--ink-light)}
.review-form{background:var(--cream);padding:20px;margin-bottom:20px;border:1.5px solid var(--border)}
.review-form-title{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta);font-weight:500;margin-bottom:14px}
.review-name-row{margin-bottom:12px}
.review-name-row input{width:100%;padding:9px 12px;background:var(--warm-white);border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;transition:border-color .2s}
.review-name-row input:focus{border-color:var(--terracotta)}
.review-name-row input::placeholder{color:var(--ink-light)}
.review-stars-pick{display:flex;gap:6px;margin-bottom:12px;align-items:center}
.review-stars-pick label{font-size:12px;color:var(--ink-light);margin-right:4px}
.review-star-pick{font-size:26px;cursor:pointer;color:#d0c8be;transition:color .12s,transform .12s;line-height:1}
.review-star-pick:hover{transform:scale(1.15)}
.review-star-pick.on{color:var(--gold)}
.review-textarea-wrap{position:relative}
.review-form textarea{width:100%;background:var(--warm-white);border:1.5px solid var(--border);padding:12px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;resize:vertical;min-height:90px;line-height:1.65;transition:border-color .2s;display:block}
.review-form textarea:focus{border-color:var(--terracotta)}
.review-form textarea::placeholder{color:var(--ink-light)}
.review-char-count{font-size:11px;color:var(--ink-light);text-align:right;margin-top:4px}
.review-form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.review-submit{background:var(--terracotta);color:white;border:none;padding:10px 24px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s,transform .15s;letter-spacing:.03em}
.review-submit:hover{background:#b04e2e;transform:translateY(-1px)}
.review-submit:disabled{background:#aaa;cursor:not-allowed;transform:none}
.review-list{display:flex;flex-direction:column;gap:10px}
.review-item{background:var(--cream);padding:16px;border-left:3px solid var(--terracotta-light)}
.review-item-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.review-item-avatar{width:32px;height:32px;background:var(--dark-green);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#F5F0E8;font-family:'Playfair Display',serif;font-size:14px;font-weight:700;flex-shrink:0}
.review-item-meta{flex:1}
.review-item-author{font-family:'Playfair Display',serif;font-size:14px;font-weight:700;color:var(--ink)}
.review-item-stars{display:flex;gap:2px}
.review-item-star{font-size:12px;color:var(--gold)}
.review-item-text{font-size:14px;line-height:1.7;color:var(--ink-light)}
.review-item-date{font-size:11px;color:var(--ink-light);margin-top:6px;opacity:.55}

/* ── ADD RECIPE MODAL ── */
.add-recipe-overlay{position:fixed;inset:0;background:var(--overlay-bg);z-index:600;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.add-recipe-overlay.open{display:flex}
.add-recipe-modal{background:var(--warm-white);width:100%;max-width:680px;position:relative;animation:fadeUp .35s ease forwards}
.add-recipe-header{background:var(--dark-green);padding:22px 28px;display:flex;justify-content:space-between;align-items:center}
.add-recipe-header h3{font-family:'Playfair Display',serif;font-size:22px;color:#F5F0E8;font-weight:700}
.add-recipe-body{padding:28px;display:flex;flex-direction:column;gap:18px}
.ar-field label{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta);font-weight:500;margin-bottom:7px}
.ar-input{width:100%;padding:10px 13px;background:var(--input-bg);border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color .2s}
.ar-input:focus{border-color:var(--terracotta)}
.ar-input::placeholder{color:var(--ink-light)}
.ar-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.ar-select{width:100%;padding:10px 13px;background:var(--input-bg);border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%234A443C' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.ar-select:focus{border-color:var(--terracotta)}
.ar-list-wrap{display:flex;flex-direction:column;gap:6px}
.ar-list-item{display:flex;gap:8px;align-items:center}
.ar-list-item input{flex:1;padding:8px 11px;background:var(--input-bg);border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none}
.ar-list-item input:focus{border-color:var(--terracotta)}
.ar-list-item button{width:28px;height:28px;background:none;border:1.5px solid var(--border);color:var(--ink-light);font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s}
.ar-list-item button:hover{border-color:var(--terracotta);color:var(--terracotta)}
.ar-add-row{display:flex;gap:8px;margin-top:4px}
.ar-add-btn{background:none;border:1.5px dashed var(--border);color:var(--ink-light);padding:7px 14px;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .2s}
.ar-add-btn:hover{border-color:var(--sage);color:var(--sage)}
.ar-photo-preview{width:100%;height:140px;object-fit:cover;display:block;margin-top:8px;background:var(--cream)}
.ar-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:6px;border-top:1px solid var(--border)}
.ar-submit{background:var(--terracotta);color:white;border:none;padding:12px 28px;font-family:'Playfair Display',serif;font-size:16px;font-style:italic;cursor:pointer;transition:background .2s}
.ar-submit:hover{background:#b04e2e}
.user-badge{background:var(--sage);color:white;font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;font-weight:600;vertical-align:middle;margin-left:6px}
