:root{
  --bg:#faf7f1; --surface:#ffffff; --ink:#2c2823; --muted:#8a8175;
  --line:#e7e0d4; --accent:#9c6b3f; --accent-soft:#f0e7da;
  --serif:'Cormorant Garamond','Iowan Old Style','Palatino Linotype','Georgia',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  line-height:1.65;-webkit-font-smoothing:antialiased;}
a{color:var(--accent);text-decoration:none;}
a:hover{text-decoration:underline;}
.wrap{max-width:1040px;margin:0 auto;padding:0 24px;}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 24px;}

/* Header */
header.site{padding:64px 0 40px;text-align:center;border-bottom:1px solid var(--line);}
header.site .kicker{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);margin:0 0 14px;font-weight:600;}
header.site h1{font-family:var(--serif);font-weight:600;font-size:3rem;line-height:1.05;
  margin:0 0 12px;letter-spacing:.5px;}
header.site p.sub{margin:0 auto;max-width:520px;color:var(--muted);font-size:1.02rem;}

/* Controls */
.controls{position:sticky;top:0;z-index:5;background:rgba(250,247,241,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:16px 0;margin-bottom:8px;}
.search{width:100%;max-width:420px;margin:0 auto 14px;display:block;padding:11px 16px;
  border:1px solid var(--line);border-radius:999px;background:var(--surface);
  font-size:.95rem;font-family:var(--sans);color:var(--ink);}
.search:focus{outline:none;border-color:var(--accent);}
.filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.chip{border:1px solid var(--line);background:var(--surface);color:var(--muted);
  padding:6px 14px;border-radius:999px;font-size:.82rem;cursor:pointer;
  transition:all .15s ease;font-family:var(--sans);}
.chip:hover{border-color:var(--accent);color:var(--accent);}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff;}

/* Sections + cards */
main{padding:28px 0 72px;}
.cat-block{margin-top:40px;}
.cat-head{display:flex;align-items:baseline;gap:14px;margin:0 0 18px;}
.cat-head h2{font-family:var(--serif);font-weight:600;font-size:1.7rem;margin:0;}
.cat-head .count{color:var(--muted);font-size:.85rem;}
.cat-head .rule{flex:1;height:1px;background:var(--line);}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:20px 20px 22px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(60,45,25,.08);
  border-color:var(--accent-soft);text-decoration:none;}
.card .tag{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);font-weight:600;}
.card h3{font-family:var(--serif);font-weight:600;font-size:1.28rem;margin:8px 0 6px;
  color:var(--ink);line-height:1.2;}
.card .meta{color:var(--muted);font-size:.85rem;}
.empty{display:none;text-align:center;color:var(--muted);padding:48px 0;font-style:italic;}

/* Recipe page */
.recipe-top{padding:34px 0 0;}
.back{display:inline-block;font-size:.85rem;margin-bottom:26px;color:var(--muted);}
.back:hover{color:var(--accent);}
.recipe-head{border-bottom:1px solid var(--line);padding-bottom:26px;margin-bottom:30px;}
.recipe-head .tag{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);font-weight:600;}
.recipe-head h1{font-family:var(--serif);font-weight:600;font-size:2.6rem;line-height:1.08;
  margin:12px 0 10px;}
.recipe-head .subtitle{font-family:var(--serif);font-style:italic;color:var(--muted);
  font-size:1.25rem;margin:0 0 12px;}
.recipe-head .serves{display:inline-block;background:var(--accent-soft);color:var(--accent);
  padding:4px 14px;border-radius:999px;font-size:.8rem;font-weight:600;}
.section-title{font-family:var(--serif);font-weight:600;font-size:1.45rem;
  margin:34px 0 14px;display:flex;align-items:center;gap:12px;}
.section-title::after{content:"";flex:1;height:1px;background:var(--line);}
.ingr-group{margin:0 0 14px;}
.ingr-group .gname{font-weight:600;font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--accent);margin:0 0 8px;}
ul.ingredients{list-style:none;margin:0;padding:0;}
ul.ingredients li{position:relative;padding:7px 0 7px 24px;border-bottom:1px solid var(--line);
  font-size:1rem;}
ul.ingredients li:last-child{border-bottom:none;}
ul.ingredients li::before{content:"";position:absolute;left:4px;top:15px;width:6px;height:6px;
  border-radius:50%;background:var(--accent);}
ol.steps{counter-reset:step;list-style:none;margin:0;padding:0;}
ol.steps li{position:relative;padding:6px 0 18px 52px;min-height:36px;}
ol.steps li::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:2px;
  width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);
  font-family:var(--serif);font-weight:600;font-size:1.1rem;display:flex;align-items:center;
  justify-content:center;}
ol.steps li:not(:last-child)::after{content:"";position:absolute;left:16px;top:38px;bottom:2px;
  width:1px;background:var(--line);}
.note{background:var(--accent-soft);border-radius:12px;padding:18px 22px;margin-top:32px;
  font-size:.95rem;color:#6e5638;}
.note .nlabel{font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem;
  color:var(--accent);display:block;margin-bottom:6px;}
footer.site{border-top:1px solid var(--line);padding:30px 0;text-align:center;
  color:var(--muted);font-size:.82rem;}
.recipe-search{margin:0;}
.chip-action{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft);}
.planner-bar{position:sticky;top:112px;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:16px;padding:12px 14px;
  box-shadow:0 12px 28px rgba(60,45,25,.06);color:var(--muted);font-size:.92rem;}
.selectable-card{padding:0;overflow:hidden;}
.select-line{display:flex;align-items:center;gap:8px;margin:0;padding:12px 16px;border-bottom:1px solid var(--line);
  color:var(--muted);font-size:.84rem;font-weight:600;cursor:pointer;}
.select-line input{width:auto;margin:0;accent-color:var(--accent);}
.card-link{display:block;padding:18px 20px 22px;color:inherit;}
.card-link:hover{text-decoration:none;}
.actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.primary-button,.text-button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;
  padding:10px 18px;font-family:var(--sans);font-size:.9rem;font-weight:700;cursor:pointer;}
.primary-button{border:1px solid var(--accent);background:var(--accent);color:#fff;}
.primary-button:hover{background:#7f542f;text-decoration:none;}
.text-button{border:1px solid var(--line);background:var(--surface);color:var(--accent);}
.text-button:hover{border-color:var(--accent);text-decoration:none;}
.recipe-form{display:grid;gap:16px;margin-bottom:54px;}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
label{display:block;margin:0 0 7px;color:var(--ink);font-weight:700;font-size:.9rem;}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:var(--surface);
  color:var(--ink);font:inherit;padding:11px 14px;}
textarea{resize:vertical;}
.button-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.form-errors{border:1px solid #d9a39a;background:#fff4f2;color:#7c3026;border-radius:14px;padding:14px 16px;}
.form-errors p{margin:0 0 8px;font-weight:700;}
.form-errors ul{margin:0;padding-left:20px;}
.plain-list{margin:0;padding-left:20px;}
.plain-list li{padding:5px 0;}
.planner-section{margin-bottom:34px;}
.message-box{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;line-height:1.5;}
.visible{display:block;}
@media(max-width:600px){
  header.site h1{font-size:2.2rem;}
  .recipe-head h1{font-size:1.9rem;}
  .form-grid{grid-template-columns:1fr;}
  .planner-bar{top:134px;align-items:stretch;flex-direction:column;}
}
