
:root{
  --bg:#f4f1ea;--card:#ffffff;--ink:#211f1b;--muted:#867c6e;--line:#ebe4d9;
  --accent:#c8542a;--accent2:#6f7d4e;--accent-soft:#f6e7db;--green:#5e7b3c;--green-soft:#e9f0dd;
  --shadow:0 1px 2px rgba(40,30,15,.05),0 10px 30px rgba(70,45,20,.07);
  --r:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.wrap{max-width:1120px;margin:0 auto;padding:0 20px}

.hero{background:linear-gradient(180deg,#fbf7f0,#f4f1ea);border-bottom:1px solid var(--line)}
.hero-in{max-width:1120px;margin:0 auto;padding:52px 20px 30px;text-align:center}
.brand{font-family:Georgia,serif;font-size:clamp(2.2rem,5.5vw,3.4rem);margin:0;letter-spacing:-.8px;color:#2c2620;font-weight:700}
.brand .dot{color:var(--accent)}
.sub{color:var(--muted);margin:.6rem 0 0;font-size:1.06rem;letter-spacing:.1px}
.count{display:inline-block;margin-top:15px;background:var(--accent-soft);color:var(--accent);padding:5px 16px;border-radius:999px;font-size:.82rem;font-weight:600;letter-spacing:.2px}

.tools{background:var(--bg);border-bottom:1px solid var(--line);padding:16px 0 6px}
.search-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search{flex:1;min-width:220px;position:relative}
.search input{width:100%;padding:13px 16px 13px 44px;border:1px solid var(--line);border-radius:14px;background:var(--card);font-size:1rem;color:var(--ink)}
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,84,42,.13)}
.search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);opacity:.42}
.btn{padding:13px 18px;border:1px solid var(--line);border-radius:14px;background:var(--card);color:var(--ink);font-size:.95rem;cursor:pointer;white-space:nowrap;font-weight:600}
.btn:hover{background:var(--accent-soft);border-color:var(--accent)}
.btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chip{padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:var(--card);color:var(--muted);font-size:.85rem;cursor:pointer;transition:.15s;user-select:none}
.chip:hover{border-color:var(--accent)}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.chip .n{opacity:.7;font-size:.78rem}

/* panel składników */
.pantry{margin-top:12px;background:linear-gradient(135deg,#fbf7ef,#f2ebdf);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.pantry-head{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none;font-weight:600}
.pantry-head .ic{font-size:1.3rem}
.pantry-head .arr{margin-left:auto;transition:.2s;opacity:.5}
.pantry.open .pantry-head .arr{transform:rotate(180deg)}
.pantry-body{display:none;padding:0 16px 16px}
.pantry.open .pantry-body{display:block}
.pantry-hint{color:var(--muted);font-size:.88rem;margin:.2rem 0 .7rem}
.pantry textarea{width:100%;min-height:54px;padding:11px 14px;border:1px solid var(--line);border-radius:12px;background:var(--card);font-size:.98rem;font-family:inherit;color:var(--ink);resize:vertical}
.pantry textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(91,122,63,.12)}
.pantry-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:11px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--card)}
.seg button{border:none;background:transparent;padding:9px 14px;font-size:.88rem;cursor:pointer;color:var(--muted);font-weight:600}
.seg button.on{background:var(--green);color:#fff}
.pantry-go{background:var(--green);color:#fff;border:none;padding:10px 18px;border-radius:10px;font-weight:700;cursor:pointer;font-size:.92rem}
.pantry-go:hover{filter:brightness(1.05)}
.pantry-clear{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;text-decoration:underline}
.sugg{margin-top:9px;display:flex;gap:6px;flex-wrap:wrap}
.sugg span{font-size:.78rem;color:var(--muted)}
.sugg b{font-size:.8rem;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:3px 10px;cursor:pointer;font-weight:500;color:var(--ink)}
.sugg b:hover{border-color:var(--green);color:var(--green)}
.sugg b .sc{opacity:.5;font-size:.72rem;margin-left:2px}

.result-info{padding:18px 0 0;color:var(--muted);font-size:.9rem;font-weight:600}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:20px;padding:16px 0 10px}
.card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s,border-color .2s;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:0 4px 10px rgba(40,30,15,.05),0 20px 42px rgba(70,45,20,.13);text-decoration:none;border-color:#e4d8c6}
.card-img{aspect-ratio:1/1;background:var(--accent-soft);position:relative;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
.card:hover .card-img img{transform:scale(1.045)}
.card-ph{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f3e7d6,#eee0cd)}
.card-in{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:.7rem;font-weight:700;color:var(--accent2);text-transform:uppercase;letter-spacing:.7px}
.card-title{font-family:Georgia,serif;font-size:1.15rem;margin:.35rem 0 .5rem;color:#2c241d;line-height:1.28;letter-spacing:-.2px}
.card-exc{color:var(--muted);font-size:.88rem;margin:0;flex:1}
.card-match{margin-top:11px;font-size:.82rem}
.card-match .ok{color:var(--green);font-weight:700}
.card-match .miss{color:var(--muted);display:block;margin-top:2px}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:11px;border-top:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.card-foot .go{color:var(--accent);font-weight:600}
.empty{text-align:center;color:var(--muted);padding:56px 20px;font-size:1.08rem}

footer{border-top:1px solid var(--line);background:var(--card);color:var(--muted);text-align:center;padding:26px 20px;font-size:.85rem;margin-top:24px}

/* ---- strona przepisu ---- */
.topbar{border-bottom:1px solid var(--line);background:var(--card);position:sticky;top:0;z-index:10}
.topbar-in{max-width:820px;margin:0 auto;padding:14px 20px;display:flex;justify-content:space-between;align-items:center}
.back{font-weight:600}
.home-link{font-family:Georgia,serif;font-size:1.12rem;color:#3a2f27}.home-link .dot{color:var(--accent)}
.article{max-width:820px;margin:0 auto;padding:30px 20px 60px}
.lead{position:relative;overflow:hidden;border-radius:20px;margin:10px 0 8px;height:clamp(215px,42vw,310px);background-size:cover;background-position:center;box-shadow:0 14px 36px rgba(70,45,20,.16)}
.lead::before{content:"";position:absolute;inset:-12%;background-image:inherit;background-size:cover;background-position:center;filter:blur(26px) brightness(.82) saturate(1.1)}
.lead::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.20))}
.lead-img{position:relative;z-index:2;width:100%;height:100%;object-fit:contain;display:block}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px;margin:.4rem 0 1rem}
.gallery img{width:100%;aspect-ratio:1/1;height:auto;object-fit:cover;display:block;border-radius:12px;box-shadow:var(--shadow);transition:.18s;cursor:zoom-in}
.gallery img:hover{transform:scale(1.04)}
.gal-h{margin-top:2.4rem}
.src{margin-top:28px;padding-top:14px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.src a{color:var(--muted);text-decoration:underline;word-break:break-word}
.src a:hover{color:var(--accent)}
.lead-img{cursor:zoom-in}
/* lightbox */
.lb{position:fixed;inset:0;background:rgba(20,14,10,.93);display:none;align-items:center;justify-content:center;z-index:200}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:90vh;border-radius:10px;box-shadow:0 10px 50px rgba(0,0,0,.5)}
.lb-btn{position:absolute;background:rgba(255,255,255,.13);color:#fff;border:none;cursor:pointer;font-family:Georgia,serif;line-height:1;border-radius:50%;transition:.15s;display:flex;align-items:center;justify-content:center}
.lb-btn:hover{background:rgba(255,255,255,.26)}
.lb-close{top:18px;right:20px;width:44px;height:44px;font-size:26px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:32px}
.lb-prev{left:16px}.lb-next{right:16px}
@media(max-width:560px){.lb-prev,.lb-next{width:42px;height:42px;font-size:26px}}
.card-ph .ph-mono{font-family:Georgia,serif;font-size:3rem;font-weight:700;color:#cbb79b}
.art-cat{display:inline-block;background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.5px;padding:4px 12px;border-radius:999px}
.art-title{font-family:Georgia,serif;font-size:clamp(1.7rem,4.5vw,2.5rem);margin:.6rem 0 .4rem;color:#2c2218;line-height:1.18}
.art-meta{color:var(--muted);font-size:.9rem;margin-bottom:8px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.art-meta span+span:before{content:"•";margin:0 8px;opacity:.5}

.recipe-body{font-size:1.05rem;color:#33291f;margin-top:22px}
.recipe-body>*:first-child{margin-top:0}
.recipe-body div{margin:0 0 .35rem}
.recipe-body div:has(>br:only-child){height:.7rem;margin:0}
.recipe-body div>br:only-child{display:none}
.recipe-body h1,.recipe-body h2,.recipe-body h3,.recipe-body h4{font-family:Georgia,serif;line-height:1.25;color:#2c2218}
.recipe-body h1{font-size:1.5rem;margin:1.7rem 0 .6rem}
.recipe-body h2{font-size:1.3rem;margin:1.5rem 0 .55rem}
.recipe-body h3{font-size:1.15rem;margin:1.4rem 0 .5rem}
.recipe-body h4{font-size:1.02rem;margin:1.2rem 0 .4rem}
.recipe-body h3.sec{color:var(--accent);font-size:1.18rem;padding-bottom:.3rem;border-bottom:2px solid var(--accent-soft);
  margin:1.8rem 0 .7rem}
.recipe-body h4.sub{font-family:Georgia,serif;font-size:1.13rem;font-weight:700;color:var(--accent);margin:1.7rem 0 .5rem;letter-spacing:-.2px}
.recipe-body h4.sub+div,.recipe-body h4.sub+ul,.recipe-body h4.sub+ol{margin-top:.2rem}
.recipe-body ul,.recipe-body ol{margin:.5rem 0 1rem;padding-left:1.5rem}
.recipe-body li{margin:.32rem 0;padding-left:.2rem}
/* checkboxy podczas gotowania */
.recipe-body li.chk{list-style:none;cursor:pointer;display:flex;align-items:flex-start;gap:.6rem;margin-left:-1.4rem;padding:.28rem .5rem;border-radius:9px;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}
.recipe-body li.chk:hover{background:var(--accent-soft)}
.recipe-body li.chk .cbx{flex:0 0 auto;width:20px;height:20px;margin-top:2px;border:2px solid var(--accent2);border-radius:6px;position:relative;transition:.15s;background:var(--card)}
.recipe-body li.chk.done{color:var(--muted);text-decoration:line-through;text-decoration-color:rgba(0,0,0,.25)}
.recipe-body li.chk.done .cbx{background:var(--accent2);border-color:var(--accent2)}
.recipe-body li.chk.done .cbx:after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.recipe-body ol{counter-reset:step}
.recipe-body ol li.chk{counter-increment:step}
.recipe-body ol li.chk:before{content:counter(step);flex:0 0 auto;min-width:1.15em;color:var(--accent);font-weight:700;font-size:.98rem;margin-top:1px}
.chk-reset{display:inline-block;margin-top:14px;background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:7px 14px;font-size:.82rem;cursor:pointer}
.chk-reset:hover{border-color:var(--accent);color:var(--accent)}
.ce{font-size:.95em}
.chip .ce,.card-cat .ce{font-size:1em}
.recipe-body a{word-break:break-word}
.recipe-body b,.recipe-body strong{color:#241c14}
.recipe-body u{text-decoration-color:var(--accent2);text-underline-offset:3px}
.r-img{max-width:100%;max-height:380px;width:auto;height:auto;border-radius:14px;margin:1.2rem auto;display:block;box-shadow:var(--shadow);cursor:zoom-in}

.nav-prevnext{display:flex;justify-content:space-between;gap:14px;margin-top:42px;padding-top:24px;border-top:1px solid var(--line)}
.nav-prevnext a{flex:1;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 16px;font-size:.9rem}
.nav-prevnext a:hover{border-color:var(--accent);text-decoration:none}
.nav-prevnext .lbl{display:block;font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.nav-prevnext .t{color:#352b23;font-weight:600}
.nav-next{text-align:right}
@media(max-width:560px){.card-img,.card-ph{height:150px}}
