:root {
  --cream:#F5F0E8; --ink:#1A1208; --warm:#C9622F; --gold:#E8A030;
  --sage:#6B8C6A; --blush:#E8C4B0; --white:#FDFAF5; --border:#D6CFC0;
  --fd:'Playfair Display',Georgia,serif; --fb:'DM Sans',sans-serif;
  --sh:4px 4px 0px var(--ink); --sh2:6px 6px 0px var(--ink);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:var(--fb);font-size:15px;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
em{font-style:italic}

header{position:sticky;top:0;z-index:100;background:var(--ink);border-bottom:2px solid var(--warm)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.5rem;font-family:var(--fd);font-size:1.4rem;color:var(--cream);letter-spacing:-.5px}
.logo-icon{color:var(--gold);font-size:1.2rem;animation:spin 8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
nav{display:flex;gap:.25rem;align-items:center}
.nav-link{color:var(--cream);font-family:var(--fb);font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.4rem 1rem;border:1.5px solid transparent;border-radius:3px;transition:all .2s}
.nav-link:hover,.nav-link.active{border-color:var(--gold);color:var(--gold)}
.fav-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--warm);color:var(--white);font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;margin-left:.3rem;vertical-align:middle;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.fav-badge.bump{transform:scale(1.4)}

.section-hero{position:relative;min-height:calc(100vh - 64px);display:flex;align-items:center;overflow:hidden;padding:4rem 2rem;background:var(--ink)}
.hero-content{max-width:1200px;margin:0 auto;width:100%;position:relative;z-index:2}
.hero-tag{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.hero-title{font-family:var(--fd);font-size:clamp(3.5rem,8vw,7rem);font-weight:900;line-height:1;color:var(--cream);margin-bottom:1.5rem;letter-spacing:-2px}
.hero-title em{color:var(--warm);display:block}
.hero-sub{color:var(--blush);font-size:1.1rem;font-weight:300;max-width:420px;margin-bottom:2.5rem}
.hero-btn{display:inline-block;background:var(--warm);color:var(--white);padding:.9rem 2rem;font-weight:500;font-size:.9rem;letter-spacing:.05em;border:2px solid var(--warm);box-shadow:var(--sh);transition:all .2s}
.hero-btn:hover{background:transparent;color:var(--warm);box-shadow:var(--sh2);transform:translate(-2px,-2px)}

.hero-art{position:absolute;right:0;top:0;width:55%;height:100%;pointer-events:none}
.art-circle{position:absolute;border-radius:50%;border:2px solid var(--warm)}
.c1{width:380px;height:380px;top:10%;right:8%;opacity:.15}
.c2{width:180px;height:180px;top:55%;right:35%;opacity:.25;border-color:var(--gold)}
.art-square{position:absolute;border:2px solid var(--sage);opacity:.2}
.s1{width:120px;height:120px;top:20%;right:20%;transform:rotate(25deg)}
.art-line{position:absolute;background:var(--border);opacity:.2}
.l1{width:1px;height:60%;top:20%;right:50%}
.l2{width:40%;height:1px;top:70%;right:5%}
.art-dot{position:absolute;border-radius:50%;background:var(--gold)}
.d1{width:10px;height:10px;top:25%;right:45%;opacity:.6}
.d2{width:6px;height:6px;top:60%;right:15%;opacity:.5}
.d3{width:14px;height:14px;top:75%;right:55%;opacity:.4}
.art-bowl{position:absolute;font-size:12rem;right:12%;top:50%;transform:translateY(-50%);opacity:.12;filter:grayscale(1)}

.section-search{background:var(--white);padding:5rem 2rem;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.section-label{text-align:center;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);margin-bottom:.75rem}
.section-title{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);font-weight:700;text-align:center;margin-bottom:2.5rem;letter-spacing:-1px}
.search-bar-wrap{display:flex;max-width:640px;margin:0 auto 2rem;box-shadow:var(--sh)}
.search-input{flex:1;border:2px solid var(--ink);border-right:none;padding:.85rem 1.2rem;font-family:var(--fb);font-size:1rem;background:var(--cream);outline:none;color:var(--ink);transition:background .2s}
.search-input:focus{background:var(--white)}
.search-btn{background:var(--ink);color:var(--cream);border:2px solid var(--ink);padding:.85rem 1.6rem;font-family:var(--fb);font-size:.85rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.search-btn:hover{background:var(--warm);border-color:var(--warm)}
.clear-btn{background:transparent;color:var(--ink);border:2px solid var(--ink);border-left:none;padding:.85rem 1rem;font-size:1rem;cursor:pointer;transition:all .2s}
.clear-btn:hover{background:var(--blush)}
.category-filters{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;justify-content:center;max-width:640px;margin:0 auto}
.filter-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#888;margin-right:.3rem}
.chip{display:flex;align-items:center;gap:.4rem;padding:.35rem .9rem;border:1.5px solid var(--border);background:var(--cream);font-size:.82rem;font-weight:500;cursor:pointer;border-radius:99px;transition:all .2s;user-select:none}
.chip:hover{border-color:var(--warm);color:var(--warm)}
.chip input[type="checkbox"]{accent-color:var(--warm)}
.chip:has(input:checked){background:var(--warm);color:var(--white);border-color:var(--warm)}
.search-message{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--warm);min-height:1.2em}

.section-recipes{padding:5rem 2rem;max-width:1200px;margin:0 auto}
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.8rem;margin-top:2rem}
.recipe-card{background:var(--white);border:2px solid var(--ink);box-shadow:var(--sh);transition:transform .2s,box-shadow .2s;cursor:pointer;position:relative;overflow:hidden;animation:cardIn .35s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.recipe-card:hover{transform:translate(-3px,-3px);box-shadow:var(--sh2)}

.card-image{width:100%;height:170px;border-bottom:2px solid var(--ink);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}

.card-category-tag{position:absolute;top:.7rem;left:.7rem;background:var(--ink);color:var(--gold);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .6rem}
.card-body{padding:1.2rem}
.card-title{font-family:var(--fd);font-size:1.2rem;font-weight:700;margin-bottom:.4rem;line-height:1.25}
.card-meta{font-size:.78rem;color:#888;margin-bottom:.9rem;text-transform:uppercase;letter-spacing:.07em}
.card-instructions-toggle{background:none;border:none;font-family:var(--fb);font-size:.8rem;font-weight:500;color:var(--warm);cursor:pointer;padding:0;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:.3rem;margin-bottom:.6rem}
.toggle-arrow{display:inline-block;transition:transform .25s}
.toggle-arrow.open{transform:rotate(90deg)}
.card-instructions{font-size:.85rem;color:#555;line-height:1.6;max-height:0;overflow:hidden;transition:max-height .4s,opacity .3s;opacity:0}
.card-instructions.visible{max-height:300px;opacity:1}
.card-footer{padding:0 1.2rem 1.2rem;display:flex;gap:.5rem}
.btn-fav{flex:1;background:var(--cream);border:1.5px solid var(--ink);color:var(--ink);padding:.5rem;font-family:var(--fb);font-size:.8rem;font-weight:500;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:all .2s}
.btn-fav:hover{background:var(--gold);border-color:var(--gold)}
.btn-fav.added{background:var(--sage);border-color:var(--sage);color:var(--white)}
.btn-view{background:var(--warm);border:1.5px solid var(--warm);color:var(--white);padding:.5rem .9rem;font-family:var(--fb);font-size:.8rem;font-weight:500;cursor:pointer;text-transform:uppercase;letter-spacing:.04em;transition:all .2s}
.btn-view:hover{background:var(--ink);border-color:var(--ink)}
.no-results{grid-column:1/-1;text-align:center;padding:4rem 2rem}
.no-results-icon{font-size:3rem;margin-bottom:1rem}
.no-results h3{font-family:var(--fd);font-size:1.5rem;margin-bottom:.5rem}

.section-favorites{padding:5rem 2rem;background:var(--ink);border-top:2px solid var(--warm)}
.section-favorites .section-label{color:var(--gold)}
.section-favorites .section-title{color:var(--cream)}
.favorites-empty{text-align:center;padding:4rem;color:#888}
.empty-icon{font-size:3rem;margin-bottom:1rem;color:var(--warm);opacity:.5}
.favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;max-width:1200px;margin:2rem auto 0}
.fav-card{background:#2A1F10;border:2px solid #3A2E1C;padding:1.2rem;transition:transform .2s,box-shadow .2s;animation:favIn .4s cubic-bezier(.34,1.56,.64,1) both}
@keyframes favIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.fav-card:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--gold)}
.fav-name{font-family:var(--fd);font-size:1.1rem;color:var(--cream);margin-bottom:.3rem}
.fav-cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin-bottom:.9rem}
.btn-remove{background:transparent;border:1.5px solid #555;color:#aaa;padding:.4rem .8rem;font-size:.75rem;font-family:var(--fb);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .2s}
.btn-remove:hover{border-color:var(--warm);color:var(--warm)}
.fav-remove-anim{animation:favOut .3s ease forwards}
@keyframes favOut{to{opacity:0;transform:scale(.8) translateY(-10px)}}

.modal-overlay{position:fixed;inset:0;background:rgba(26,18,8,.85);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-card{background:var(--white);border:2px solid var(--ink);box-shadow:8px 8px 0 var(--warm);max-width:560px;width:100%;max-height:85vh;overflow-y:auto;padding:2.5rem;position:relative;transform:translateY(30px);transition:transform .3s}
.modal-overlay.open .modal-card{transform:translateY(0)}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:1.5px solid var(--ink);width:34px;height:34px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.modal-close:hover{background:var(--warm);color:#fff;border-color:var(--warm)}
.modal-cat-tag{display:inline-block;background:var(--ink);color:var(--gold);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .6rem;margin-bottom:1rem}
.modal-title{font-family:var(--fd);font-size:2rem;font-weight:700;margin-bottom:1.5rem;line-height:1.15}
.modal-section-head{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--warm);margin-bottom:.6rem;border-bottom:1px solid var(--border);padding-bottom:.4rem}
.modal-ingredients{list-style:none;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:.4rem}
.modal-ingredients li{background:var(--cream);border:1.5px solid var(--border);font-size:.82rem;padding:.25rem .7rem;border-radius:99px}
.modal-instructions{font-size:.9rem;line-height:1.8;color:#444;margin-bottom:1.5rem}

footer{background:#0E0B05;border-top:2px solid var(--warm);padding:2.5rem 2rem}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center}
.footer-logo{font-family:var(--fd);font-size:1.3rem;color:var(--cream)}
.footer-copy{font-size:.82rem;color:#666}
.footer-links{display:flex;gap:.6rem;font-size:.82rem;color:#888}
.footer-links a:hover{color:var(--gold)}

@media(max-width:700px){
  .hero-art{display:none}
  .header-inner{padding:0 1rem}
  nav{gap:0}
  .nav-link{padding:.4rem .6rem;font-size:.75rem}
}

/* --- NEW STYLES FOR IMAGES AND REVIEWS --- */
.fav-image {
  width: 55px; height: 55px; border-radius: 50%;
  background-size: cover; background-position: center;
  margin-bottom: 0.8rem; border: 2px solid var(--gold);
}
.modal-image {
  width: 90px; height: 90px; border-radius: 50%;
  background-size: cover; background-position: center;
  margin-bottom: 1rem; border: 3px solid var(--warm);
  box-shadow: var(--sh);
}
.reviews-container {
  display: flex; flex-direction: column; gap: 0.8rem; margin-bottom: 1.5rem;
}
.review-card {
  background: var(--cream); border: 1.5px solid var(--border);
  padding: 0.8rem 1rem; border-radius: 6px;
  animation: slideInRev 0.4s cubic-bezier(0.25, 1, 0.5, 1) both;
}
@keyframes slideInRev {
  from { opacity: 0; transform: translateX(-15px); }
  to { opacity: 1; transform: translateX(0); }
}
.review-stars { color: var(--gold); font-size: 0.95rem; margin-bottom: 0.2rem; letter-spacing: 2px; }
.review-author { font-weight: 700; font-family: var(--fd); font-size: 0.95rem; color: var(--ink); }
.review-text { font-size: 0.85rem; color: #555; font-style: italic; margin-top: 0.3rem;}