
  :root{
    --cream:#FFFCF7;
    --cream-deep:#FBF1E6;
    --ink:#352F2A;
    --ink-soft:#766F65;
    --sage:#8FB096;
    --sage-deep:#5C7E63;
    --blush:#FAD9D1;
    --blush-deep:#EBA89B;
    --butter:#F6CB63;
    --butter-soft:#FBE6AE;
    --mint:#E9F2EA;
    --lilac:#E7DDF2;
    --white:#FFFFFF;
    --shadow:0 24px 50px -26px rgba(92,126,99,.5);
    --shadow-sm:0 12px 28px -18px rgba(53,47,42,.45);
    --radius:30px;
    --radius-sm:18px;
    --nav-h:72px;
    --serif:"Fraunces",Georgia,serif;
    --sans:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{max-width:100%;overflow-x:hidden}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{
    font-family:var(--sans);color:var(--ink);background:var(--cream);
    line-height:1.62;-webkit-font-smoothing:antialiased;position:relative;
  }
  .blob{position:fixed;border-radius:50%;filter:blur(70px);z-index:0;pointer-events:none;opacity:.5}
  .blob.b1{width:min(480px,60vw);height:min(480px,60vw);background:var(--blush);top:-120px;right:-80px}
  .blob.b2{width:min(420px,55vw);height:min(420px,55vw);background:var(--mint);top:42%;left:-140px}
  .blob.b3{width:min(380px,50vw);height:min(380px,50vw);background:var(--butter-soft);bottom:-120px;right:-60px;opacity:.4}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:1140px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
  section[id]{scroll-margin-top:calc(var(--nav-h) + 12px)}
  h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.015em;overflow-wrap:break-word}
  .eyebrow{font-size:clamp(.72rem,2.4vw,.78rem);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-deep);display:inline-flex;align-items:center;gap:.5em}

  .sticker{display:inline-flex;align-items:center;gap:.45em;background:#fff;border:2px solid var(--ink);border-radius:999px;padding:.45em 1em;font-size:clamp(.74rem,2.6vw,.82rem);font-weight:700;box-shadow:3px 3px 0 var(--ink);transform:rotate(-2deg);max-width:100%}
  .sticker .em{font-size:1.05em}

  .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:700;font-size:.96rem;padding:.78em 1.5em;border-radius:999px;border:none;cursor:pointer;font-family:var(--sans);transition:transform .16s cubic-bezier(.34,1.56,.64,1),box-shadow .2s,background .2s;-webkit-tap-highlight-color:transparent}
  .btn-primary{background:var(--sage-deep);color:#fff;box-shadow:0 6px 0 -1px #45603f}
  .btn-primary:hover{transform:translateY(-3px);box-shadow:0 9px 0 -1px #45603f}
  .btn-primary:active{transform:translateY(1px);box-shadow:0 3px 0 -1px #45603f}
  .btn-ghost{background:#fff;color:var(--ink);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--ink)}
  .btn-ghost:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--ink)}
  .btn-ghost:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}

  /* ---------- nav ---------- */
  header.nav{position:sticky;top:0;z-index:50;background:rgba(255,252,247,.82);backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid rgba(143,176,150,.2)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
  .brand{display:flex;align-items:center;gap:.55rem;font-family:var(--serif);font-size:1.35rem;font-weight:600;letter-spacing:-.02em;flex-shrink:0}
  .brand .dot{width:34px;height:34px;border-radius:50%;background:radial-gradient(circle at 32% 28%,var(--butter),var(--blush-deep));display:grid;place-items:center;font-size:1rem;box-shadow:var(--shadow-sm);animation:bob 4s ease-in-out infinite}
  .nav-links{display:flex;align-items:center;gap:.4rem}
  .nav-links a{font-size:.95rem;font-weight:600;color:var(--ink-soft);padding:.5em .9em;border-radius:999px;transition:color .2s,background .2s}
  .nav-links a:hover{color:var(--ink);background:var(--mint)}
  .nav-cta{display:flex;align-items:center;gap:.8rem}
  .menu-toggle{display:none;background:#fff;border:2px solid var(--ink);width:44px;height:44px;border-radius:14px;font-size:1.3rem;cursor:pointer;line-height:1;box-shadow:2px 2px 0 var(--ink);-webkit-tap-highlight-color:transparent}

  /* ---------- hero ---------- */
  .hero{padding:60px 0 36px}
  .hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:48px;align-items:center}
  .hero h1{font-size:clamp(2.3rem,6vw,4.1rem);margin:1.1rem 0 1.2rem}
  .squig{position:relative;white-space:nowrap;color:var(--sage-deep);font-style:italic}
  .squig svg{position:absolute;left:0;right:0;bottom:-.3em;width:100%;height:.4em}
  .hero p.lead{font-size:clamp(1.05rem,3.4vw,1.2rem);color:var(--ink-soft);max-width:33ch;margin-bottom:2rem}
  .hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
  .hero-stats{display:flex;gap:.6rem;margin-top:2.2rem;flex-wrap:wrap}
  .pill{background:#fff;border:1.5px solid rgba(143,176,150,.45);border-radius:999px;padding:.55em 1em;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.45em;box-shadow:var(--shadow-sm)}
  .pill .em{font-size:1.05em}

  .portrait-wrap{position:relative;justify-self:center;width:min(360px,78vw)}
  .portrait-ring{position:relative;width:100%;aspect-ratio:1;border-radius:50%;padding:14px;background:conic-gradient(from 0deg,var(--blush),var(--butter-soft),var(--mint),var(--lilac),var(--blush));box-shadow:var(--shadow)}
  .portrait{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;background:linear-gradient(150deg,var(--blush),var(--mint));border:6px solid #fff}
  .portrait img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
  .portrait .fallback{width:100%;height:100%;display:grid;place-items:center;text-align:center;font-family:var(--serif);color:var(--sage-deep)}
  .portrait .fallback .big{font-size:4rem}
  .speech{position:absolute;top:4px;right:-6px;z-index:4;background:#fff;border:2px solid var(--ink);border-radius:18px 18px 18px 4px;padding:.5em .85em;font-weight:700;font-size:clamp(.78rem,2.6vw,.9rem);box-shadow:3px 3px 0 var(--ink);transform:rotate(4deg);white-space:nowrap}
  .stkr{position:absolute;z-index:3;font-size:clamp(1.4rem,5vw,2rem);filter:drop-shadow(0 6px 8px rgba(0,0,0,.12))}
  .stkr.s1{top:8%;left:-10px;animation:float 5s ease-in-out infinite}
  .stkr.s2{bottom:6%;right:-2px;animation:float 6s ease-in-out infinite .8s}
  .stkr.s3{bottom:20%;left:-16px;font-size:clamp(1.1rem,4vw,1.6rem);animation:float 5.5s ease-in-out infinite .4s}
  .badge-float{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%) rotate(-3deg);z-index:5;background:var(--butter);border:2px solid var(--ink);border-radius:999px;padding:.4em 1em;font-size:clamp(.74rem,2.6vw,.82rem);font-weight:800;box-shadow:3px 3px 0 var(--ink);white-space:nowrap}

  /* ---------- marquee ---------- */
  .marquee{margin-top:34px;padding:15px 0;border-top:2px dashed rgba(143,176,150,.4);border-bottom:2px dashed rgba(143,176,150,.4);overflow:hidden;background:rgba(233,242,234,.4)}
  .marquee-track{display:flex;white-space:nowrap;width:max-content;animation:slide 26s linear infinite;font-family:var(--serif);font-size:clamp(1rem,3vw,1.15rem);color:var(--sage-deep)}
  .marquee-track span{display:inline-flex;align-items:center}
  .marquee:hover .marquee-track{animation-play-state:paused}

  /* ---------- section ---------- */
  .section{padding:80px 0}
  .section-head{text-align:center;max-width:48ch;margin:0 auto 50px}
  .section-head h2{font-size:clamp(1.9rem,5vw,2.9rem);margin:.7rem 0 .8rem}
  .section-head p{color:var(--ink-soft)}

  /* ---------- about ---------- */
  .about-card{position:relative;background:var(--white);border:2px solid var(--ink);border-radius:var(--radius);padding:46px 50px;display:grid;grid-template-columns:auto 1fr;gap:42px;align-items:center;box-shadow:8px 8px 0 rgba(92,126,99,.2)}
  .about-ava{position:relative;width:130px;height:130px;flex-shrink:0}
  .about-ava .ring{width:100%;height:100%;border-radius:50%;overflow:hidden;border:5px solid #fff;box-shadow:0 0 0 3px var(--blush-deep);background:linear-gradient(150deg,var(--blush),var(--mint))}
  .about-ava img{width:100%;height:100%;object-fit:cover}
  .about-ava .fallback{width:100%;height:100%;display:grid;place-items:center;font-family:var(--serif);font-size:2.6rem;color:var(--sage-deep)}
  .about-ava .tag{position:absolute;bottom:-8px;right:-8px;font-size:1.5rem}
  .about h2{font-size:clamp(1.6rem,4.4vw,2rem);margin:.5rem 0 .7rem}
  .about p{color:var(--ink-soft);max-width:60ch;margin-bottom:.6rem}
  .about .sig{font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,3vw,1.18rem);color:var(--sage-deep)}

  /* ---------- recipes ---------- */
  .recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .card{background:#fff;border:2px solid var(--ink);border-radius:var(--radius);overflow:hidden;box-shadow:6px 6px 0 rgba(92,126,99,.18);display:flex;flex-direction:column;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s}
  .card:hover{transform:translate(-2px,-4px) rotate(-.6deg);box-shadow:10px 12px 0 rgba(92,126,99,.22)}
  .card-img{aspect-ratio:4/3;position:relative;display:grid;place-items:center;font-size:3.4rem;border-bottom:2px solid var(--ink)}
  .card-img.r1{background:linear-gradient(150deg,#F8E3C2,#EBCFA2)}
  .card-img.r2{background:linear-gradient(150deg,#FAD9D1,#F1BBAD)}
  .card-img.r3{background:linear-gradient(150deg,#E1ECDC,#C6DAC4)}
  .card-img .tag{position:absolute;top:14px;left:14px;background:#fff;border:1.5px solid var(--ink);font-size:.74rem;font-weight:800;padding:.34em .8em;border-radius:999px;color:var(--ink);box-shadow:2px 2px 0 var(--ink)}
  .card-img .heart{position:absolute;top:12px;right:14px;font-size:1.2rem;opacity:0;transition:opacity .2s,transform .2s}
  .card:hover .heart{opacity:1;transform:scale(1.2) rotate(8deg)}
  .card-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:.6rem;flex:1}
  .card-body h3{font-size:1.3rem}
  .card-meta{display:flex;gap:1rem;font-size:.82rem;color:var(--ink-soft);font-weight:600}
  .card-meta span{display:flex;align-items:center;gap:.3rem}
  .benefit-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}
  .benefit-tags span{font-size:.72rem;background:var(--mint);color:var(--sage-deep);padding:.32em .7em;border-radius:999px;font-weight:700}
  .card-link{margin-top:auto;padding-top:.7rem;font-weight:700;color:var(--sage-deep);font-size:.92rem}
  .section-cta{text-align:center;margin-top:44px}

  /* ---------- guides ---------- */
  .guides{position:relative;background:linear-gradient(135deg,var(--sage-deep),#4a684f);color:#fff;border-radius:36px;padding:56px;overflow:hidden;border:2px solid var(--ink);box-shadow:8px 8px 0 rgba(92,126,99,.25)}
  .guides::after{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:rgba(246,203,99,.25);top:-110px;right:-70px}
  .guides .sparkle{position:absolute;font-size:1.4rem;opacity:.6}
  .guides .sp1{top:30px;left:40px}.guides .sp2{bottom:40px;left:24%}.guides .sp3{top:50px;right:30%}
  .guides-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr 1fr;gap:46px;align-items:center}
  .guides .eyebrow{color:var(--butter)}
  .guides h2{color:#fff;font-size:clamp(1.8rem,5vw,2.3rem);margin:.5rem 0 .9rem}
  .guides p{color:rgba(255,255,255,.82);max-width:42ch}
  .guide-mock .cover{aspect-ratio:3/4;max-width:300px;margin:0 auto;border-radius:20px;background:linear-gradient(160deg,#fff,var(--cream-deep));display:flex;flex-direction:column;justify-content:space-between;padding:24px;color:var(--ink);box-shadow:var(--shadow);border:2px solid var(--ink);transform:rotate(2deg);transition:transform .3s}
  .guide-mock .cover:hover{transform:rotate(-1deg) scale(1.02)}
  .guide-mock .cover .label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-deep);font-weight:800}
  .guide-mock .cover h4{font-size:1.55rem;line-height:1.1}
  .guide-mock .cover .meals{font-size:1.8rem;letter-spacing:.08em}

  /* ---------- newsletter ---------- */
  .news-card{position:relative;background:var(--cream-deep);border:2px solid var(--ink);border-radius:36px;padding:64px 38px;text-align:center;overflow:hidden;box-shadow:8px 8px 0 rgba(92,126,99,.2)}
  .news-card .sp{position:absolute;font-size:1.6rem;opacity:.45;pointer-events:none;line-height:1}
  .news-card .spa{top:28px;left:34px}
  .news-card .spb{top:28px;right:34px}
  .news-card .spc{bottom:28px;left:34px}
  .news-card .spd{bottom:28px;right:34px}
  .news h2{font-size:clamp(1.9rem,5vw,2.9rem);margin-bottom:.7rem;position:relative}
  .news p{color:var(--ink-soft);max-width:48ch;margin:0 auto 2rem;position:relative}
  .signup{display:flex;gap:.7rem;max-width:480px;margin:0 auto;position:relative;flex-wrap:wrap;justify-content:center}
  .signup input{flex:1;min-width:200px;padding:.95em 1.25em;border-radius:999px;border:2px solid var(--ink);font-family:var(--sans);font-size:1rem;background:#fff}
  .signup input:focus{outline:none;box-shadow:3px 3px 0 var(--sage-deep)}
  .signup .btn{flex-shrink:0}
  #signupMsg{margin-top:1.5rem}
  /* Soft drop shadow so the button sits flush/aligned with the input (no protruding hard-shadow band) */
  .signup .btn-primary{box-shadow:0 4px 14px rgba(92,126,99,.32)}
  .signup .btn-primary:hover{transform:translateY(-2px);box-shadow:0 7px 18px rgba(92,126,99,.4)}
  .signup .btn-primary:active{transform:translateY(0);box-shadow:0 3px 10px rgba(92,126,99,.38)}
  .fineprint{font-size:.82rem;color:var(--ink-soft);margin-top:1.1rem;position:relative}

  /* ---------- footer ---------- */
  footer{padding:60px 0 36px;margin-top:30px;border-top:2px dashed rgba(143,176,150,.4)}
  .foot-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
  .foot-brand{max-width:32ch}
  .foot-brand p{color:var(--ink-soft);font-size:.92rem;margin-top:.6rem}
  .socials{display:flex;gap:.7rem;margin-top:1.2rem}
  .socials a{width:46px;height:46px;border-radius:50%;background:#fff;border:2px solid var(--ink);display:grid;place-items:center;font-size:1.15rem;box-shadow:2px 2px 0 var(--ink);transition:transform .16s}
  .socials a img{width:23px;height:23px;display:block}
  .socials a:hover{transform:translate(-1px,-2px) rotate(-6deg)}
  .foot-links{display:flex;gap:56px}
  .foot-col h5{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:1rem;font-family:var(--sans);font-weight:800}
  .foot-col a{display:block;color:var(--ink-soft);font-size:.92rem;margin-bottom:.6rem;transition:color .2s}
  .foot-col a:hover{color:var(--ink)}
  .copyright{text-align:center;color:var(--ink-soft);font-size:.82rem;margin-top:46px}

  /* ---------- animations ---------- */
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  @keyframes bob{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-3px) rotate(8deg)}}
  @keyframes slide{to{transform:translateX(-50%)}}
  @media(prefers-reduced-motion:reduce){*{animation:none!important}}

  /* ---------- tablet ---------- */
  @media(max-width:1000px){
    .hero-grid{gap:36px}
    .recipe-grid{grid-template-columns:1fr 1fr}
    .recipe-grid .card:last-child{grid-column:1 / -1;max-width:520px;margin:0 auto;width:100%}
  }

  /* ---------- mobile ---------- */
  @media(max-width:760px){
    .wrap{padding:0 20px}
    .nav-links{
      position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;align-items:stretch;
      gap:.15rem;background:var(--cream);border-bottom:1px solid rgba(143,176,150,.3);
      padding:14px 20px 20px;box-shadow:var(--shadow-sm);display:none;
    }
    .nav-links a{padding:.85em 1em;border-radius:14px;font-size:1.05rem}
    body.nav-open .nav-links{display:flex}
    .menu-toggle{display:grid;place-items:center}
    .nav-cta .btn-primary{display:none}

    .hero{padding:36px 0 20px}
    .hero-grid{grid-template-columns:1fr;gap:40px;text-align:center}
    .hero .hero-copy{order:2}
    .portrait-wrap{order:1;width:min(300px,72vw)}
    .hero p.lead{margin-left:auto;margin-right:auto}
    .hero-cta,.hero-stats{justify-content:center}
    .hero-cta .btn{flex:1 1 auto;min-width:160px}

    .section{padding:54px 0}
    .section-head{margin-bottom:36px}
    .about-card{grid-template-columns:1fr;text-align:center;justify-items:center;padding:38px 24px;gap:24px;box-shadow:6px 6px 0 rgba(92,126,99,.2)}
    .about p{margin-left:auto;margin-right:auto}
    .recipe-grid{grid-template-columns:1fr;gap:22px}
    .recipe-grid .card:last-child{max-width:none}
    .guides{padding:38px 26px;box-shadow:6px 6px 0 rgba(92,126,99,.25)}
    .guides-grid{grid-template-columns:1fr;gap:30px;text-align:center}
    .guides p{margin-left:auto;margin-right:auto}
    .guides .btn{width:100%;max-width:340px}
    .guide-mock{order:-1}
    .news-card{padding:48px 24px;box-shadow:6px 6px 0 rgba(92,126,99,.2)}
    .news-card .sp{font-size:1.3rem;opacity:.4}
    .news-card .spa,.news-card .spc{left:18px}.news-card .spb,.news-card .spd{right:18px}
    .news-card .spa,.news-card .spb{top:20px}.news-card .spc,.news-card .spd{bottom:20px}
    .signup input{min-width:0;flex:1 1 100%}
    .signup .btn{width:100%}
    .foot-grid{flex-direction:column;gap:32px}
    .foot-links{gap:48px}
  }

  /* ---------- small phones ---------- */
  @media(max-width:380px){
    .wrap{padding:0 16px}
    .brand{font-size:1.2rem}
    .brand .dot{width:30px;height:30px}
    .stkr.s1,.stkr.s3{left:-2px}
    .stkr.s2{right:2px}
    .hero-stats{gap:.5rem}
    .pill{font-size:.8rem;padding:.5em .85em}
  }


  /* ============ recipes page ============ */
  .recipes-hero{padding:50px 0 8px;text-align:center}
  .recipes-hero h1{font-size:clamp(2.2rem,6vw,3.5rem);margin:.7rem 0 .6rem}
  .recipes-hero p{color:var(--ink-soft);max-width:50ch;margin:0 auto}
  .toolbar{position:sticky;top:var(--nav-h);z-index:40;background:rgba(255,252,247,.92);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);padding:18px 0;margin-bottom:26px;border-bottom:1px solid rgba(143,176,150,.22)}
  .toolbar-inner{display:flex;flex-direction:column;gap:14px}
  .search-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
  .search-box{flex:1;min-width:220px;position:relative}
  .search-box input{width:100%;padding:.85em 1em .85em 2.7em;border-radius:999px;border:2px solid var(--ink);font-family:var(--sans);font-size:1rem;background:#fff;box-shadow:3px 3px 0 var(--ink)}
  .search-box input:focus{outline:none;box-shadow:5px 5px 0 var(--sage-deep)}
  .search-box .mag{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-size:1.05rem;pointer-events:none}
  .sort-select{border:2px solid var(--ink);border-radius:999px;padding:.78em 1.1em;font-family:var(--sans);font-weight:700;font-size:.9rem;background:#fff;cursor:pointer;box-shadow:3px 3px 0 var(--ink)}
  .chips{display:flex;gap:.5rem;flex-wrap:wrap}
  .chip-btn{border:2px solid var(--ink);background:#fff;border-radius:999px;padding:.5em 1.1em;font-family:var(--sans);font-weight:700;font-size:.88rem;cursor:pointer;transition:transform .14s,box-shadow .14s,background .14s,color .14s;box-shadow:2px 2px 0 var(--ink);-webkit-tap-highlight-color:transparent}
  .chip-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
  .chip-btn.active{background:var(--sage-deep);color:#fff}
  .results-count{font-size:.9rem;color:var(--ink-soft);font-weight:700;margin-bottom:18px}
  .all-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .all-grid .card{cursor:pointer;text-decoration:none;color:inherit}
  .pop-badge{position:absolute;top:12px;right:14px;background:#fff;border:1.5px solid var(--ink);border-radius:999px;padding:.22em .6em;font-size:.74rem;font-weight:800;box-shadow:2px 2px 0 var(--ink);color:var(--blush-deep)}
  .empty{grid-column:1/-1;text-align:center;padding:64px 20px;color:var(--ink-soft)}
  .empty .big{font-size:3.2rem;display:block;margin-bottom:.4rem}
  /* recipe card colour variants */
  .card-img.c0{background:linear-gradient(150deg,#F8E3C2,#EBCFA2)}
  .card-img.c1{background:linear-gradient(150deg,#FAD9D1,#F1BBAD)}
  .card-img.c2{background:linear-gradient(150deg,#E1ECDC,#C6DAC4)}
  .card-img.c3{background:linear-gradient(150deg,#E7DDF2,#D2C2E8)}
  .card-img.c4{background:linear-gradient(150deg,#FBE6AE,#F4CB63)}
  .card-img.c5{background:linear-gradient(150deg,#D9E8EC,#B9D6DE)}
  @media(max-width:1000px){ .all-grid{grid-template-columns:1fr 1fr} }
  @media(max-width:760px){
    .toolbar{position:static}
    .search-row{flex-direction:column;align-items:stretch}
    .sort-select{width:100%}
  }
  @media(max-width:620px){ .all-grid{grid-template-columns:1fr} }

  /* ============ recipe detail page ============ */
  .rd-back{display:inline-flex;align-items:center;gap:.4em;font-weight:700;color:var(--sage-deep);margin:26px 0 4px}
  .rd-back:hover{text-decoration:underline}
  .rd-head{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin:8px 0}
  .rd-emoji{width:100px;height:100px;border-radius:26px;border:2px solid var(--ink);display:grid;place-items:center;font-size:3.2rem;box-shadow:5px 5px 0 var(--ink);flex-shrink:0}
  .rd-title{flex:1;min-width:240px}
  .rd-title h1{font-size:clamp(1.9rem,5vw,3rem);margin:0 0 .55rem}
  .rd-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
  .rd-meta .m{background:#fff;border:1.5px solid rgba(143,176,150,.55);border-radius:999px;padding:.38em .85em;font-size:.82rem;font-weight:700;display:inline-flex;gap:.35em;align-items:center}
  .rd-intro{font-size:1.12rem;color:var(--ink-soft);max-width:64ch;margin:14px 0 2px;line-height:1.7}
  .rd-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:.8rem 0 0}
  .rd-tags span{font-size:.74rem;background:var(--mint);color:var(--sage-deep);padding:.36em .8em;border-radius:999px;font-weight:700}
  .rd-grid{display:grid;grid-template-columns:320px 1fr;gap:34px;margin-top:32px;align-items:start}
  .rd-card{background:#fff;border:2px solid var(--ink);border-radius:26px;padding:26px 28px;box-shadow:6px 6px 0 rgba(92,126,99,.18)}
  .rd-card h2{font-size:1.35rem;margin-bottom:16px}
  .ing-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}
  .ing-list li{display:flex;gap:.65rem;align-items:flex-start;font-size:.98rem}
  .ing-list li::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--blush-deep);margin-top:.5em;flex-shrink:0}
  .steps{list-style:none;counter-reset:s;display:flex;flex-direction:column;gap:18px}
  .steps li{counter-increment:s;display:flex;gap:15px;align-items:flex-start;font-size:1.02rem;line-height:1.6}
  .steps li::before{content:counter(s);flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--sage-deep);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.92rem;font-family:var(--sans)}
  .rd-section{margin-top:34px}
  .rd-section h2{font-size:1.6rem;margin-bottom:14px}
  .freeform-body{white-space:pre-line;font-size:1.04rem;color:var(--ink);line-height:1.85;max-width:68ch}
  .benefit-box{background:var(--cream-deep);border:2px solid var(--ink);border-radius:26px;padding:28px 30px;margin-top:34px;box-shadow:6px 6px 0 rgba(92,126,99,.18)}
  .benefit-box h2{font-size:1.4rem;margin-bottom:12px}
  .benefit-box ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
  .benefit-box li{display:flex;gap:.55rem;align-items:flex-start}
  .benefit-box li::before{content:"✨";flex-shrink:0}
  .teaser-note{background:var(--butter-soft);border:2px solid var(--ink);border-radius:20px;padding:18px 22px;margin-top:22px;font-weight:600;display:flex;gap:.6rem;align-items:flex-start}
  .rd-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:30px}
  .rd-news{margin:50px 0 6px;text-align:center;background:linear-gradient(135deg,var(--sage-deep),#4a684f);color:#fff;border:2px solid var(--ink);border-radius:30px;padding:40px 30px;box-shadow:8px 8px 0 rgba(92,126,99,.25)}
  .rd-news h2{color:#fff;font-size:1.7rem;margin-bottom:.5rem}
  .rd-news p{color:rgba(255,255,255,.85);margin-bottom:1.3rem}
  .rd-notfound{text-align:center;padding:80px 20px}
  .rd-notfound .big{font-size:3.5rem;display:block;margin-bottom:.4rem}
  @media(max-width:760px){
    .rd-grid{grid-template-columns:1fr;gap:24px}
    .rd-emoji{width:80px;height:80px;font-size:2.6rem}
  }

  /* ============ recipe photos ============ */
  .card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
  .card-img .tag,.card-img .pop-badge,.card-img .heart{z-index:2}
  .rd-hero{margin:18px 0 4px}
  .rd-hero img{width:100%;max-height:440px;object-fit:cover;border-radius:26px;border:2px solid var(--ink);box-shadow:6px 6px 0 rgba(92,126,99,.18)}
