:root{
  --paper:#F6F3EC;
  --paper-raised:#FFFFFF;
  --ink:#2B2A25;
  --ink-soft:#6B6A62;
  --sage:#6B8F71;
  --sage-dark:#3E5A42;
  --sage-tint:#E4ECE3;
  --clay:#C1622D;
  --clay-tint:#F3E1D3;
  --gold:#C9992F;
  --rose:#B6473F;
  --rose-tint:#F3DEDB;
  --line:#DDD6C7;
}
*{box-sizing:border-box;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:760px;margin:0 auto;padding:28px 20px 80px;}

header.top{margin-bottom:22px;}
.eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--sage-dark);margin-bottom:6px;display:flex;gap:10px;align-items:center;
}
.eyebrow input{
  font-family:'JetBrains Mono',monospace;font-size:11px;border:1px solid var(--line);
  background:var(--paper-raised);padding:3px 6px;border-radius:3px;color:var(--ink);
}
h1{
  font-family:'Fraunces',serif;font-weight:600;font-size:34px;margin:0 0 4px;
  letter-spacing:-.01em;
}
.sub{color:var(--ink-soft);font-size:14px;margin:0;}

nav.tabs{
  display:flex;gap:2px;border-bottom:1px solid var(--line);margin:26px 0 22px;
  overflow-x:auto;
}
nav.tabs button{
  font-family:'Inter',sans-serif;font-size:13.5px;font-weight:600;
  background:none;border:none;padding:10px 14px 12px;cursor:pointer;
  color:var(--ink-soft);border-bottom:2px solid transparent;white-space:nowrap;
  transition:color .15s;
}
nav.tabs button.active{color:var(--ink);border-bottom-color:var(--clay);}
nav.tabs button:hover{color:var(--ink);}

.view{display:none;}
.view.active{display:block;}

/* ---- Vandaag: ledger strip ---- */
.strip{
  display:flex;gap:6px;margin-bottom:22px;overflow-x:auto;padding-bottom:4px;
}
.strip .day{
  flex:0 0 auto;width:38px;text-align:center;
}
.strip .day .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-soft);}
.strip .day .dot{
  width:14px;height:14px;border-radius:50%;margin:4px auto 0;
  background:var(--line);
}

.card{
  background:var(--paper-raised);border:1px solid var(--line);border-radius:6px;
  padding:18px;margin-bottom:16px;
}
.card h3{font-family:'Fraunces',serif;font-size:17px;margin:0 0 12px;font-weight:600;}

.field{margin-bottom:12px;}
.field label{display:block;font-size:12px;color:var(--ink-soft);margin-bottom:5px;font-weight:600;}
.field input[type=text], .field select, .field textarea{
  width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:4px;
  font-family:'Inter',sans-serif;font-size:14px;background:var(--paper);color:var(--ink);
}
.row2{display:flex;gap:10px;}
.row2 .field{flex:1;}

input[type=range]{width:100%;accent-color:var(--clay);}
.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-soft);font-family:'JetBrains Mono',monospace;}

button.primary{
  background:var(--clay);color:#fff;border:none;padding:10px 18px;border-radius:4px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13.5px;cursor:pointer;
}
button.primary:hover{background:#a8531f;}
button.ghost{
  background:none;border:1px solid var(--line);color:var(--ink-soft);
  padding:6px 10px;border-radius:4px;font-size:12px;cursor:pointer;font-family:'Inter',sans-serif;
}

.log-entry{
  display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--line);
  font-size:14px;align-items:flex-start;
}
.log-entry:first-of-type{border-top:none;}
.log-entry .time{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-soft);
  width:44px;flex:0 0 44px;padding-top:2px;
}
.log-entry .body{flex:1;}
.log-entry .meal-tag{
  font-size:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;
  color:var(--sage-dark);
}
.log-entry .score{
  font-family:'JetBrains Mono',monospace;font-size:12px;flex:0 0 auto;
  width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;
}
.empty{color:var(--ink-soft);font-size:13.5px;font-style:italic;padding:8px 0;}

/* ---- Recepten ---- */
.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.chip{
  padding:6px 13px;border-radius:20px;border:1px solid var(--line);background:var(--paper-raised);
  font-size:12.5px;cursor:pointer;font-weight:500;color:var(--ink-soft);
}
.chip.active{background:var(--sage);color:#fff;border-color:var(--sage);}

.recipe{
  background:var(--paper-raised);border:1px solid var(--line);border-radius:6px;
  margin-bottom:12px;overflow:hidden;
}
.recipe-head{
  display:flex;justify-content:space-between;align-items:center;padding:14px 16px;cursor:pointer;
}
.recipe-head .titles{display:flex;flex-direction:column;gap:3px;}
.recipe-head h4{margin:0;font-family:'Fraunces',serif;font-size:16px;font-weight:600;}
.meta{display:flex;gap:8px;align-items:center;}
.tag{
  font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;
  color:var(--sage-dark);background:var(--sage-tint);padding:2px 7px;border-radius:3px;
}
.time-tag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-soft);}
.recipe-body{
  display:none;padding:0 16px 16px;border-top:1px solid var(--line);
}
.recipe.open .recipe-body{display:block;padding-top:14px;}
.recipe.open .chevron{transform:rotate(180deg);}
.chevron{transition:transform .15s;color:var(--ink-soft);}
.recipe-body h5{
  font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);
  margin:12px 0 6px;
}
.recipe-body h5:first-child{margin-top:0;}
.recipe-body ul{margin:0;padding-left:18px;font-size:13.5px;}
.recipe-body ol{margin:0;padding-left:18px;font-size:13.5px;}
.recipe-body li{margin-bottom:4px;}
.add-week{
  margin-top:12px;display:flex;align-items:center;gap:7px;font-size:13px;cursor:pointer;
}

/* ---- Boodschappen ---- */
.shop-item{
  display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--line);font-size:14px;
}
.shop-item:first-of-type{border-top:none;}
.shop-item.checked span{text-decoration:line-through;color:var(--ink-soft);}
.shop-item input{width:16px;height:16px;accent-color:var(--sage);}

/* ---- Gids ---- */
.guide-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:520px){.guide-grid{grid-template-columns:1fr;}}
.guide-col h4{
  font-family:'Fraunces',serif;font-size:15px;margin:0 0 8px;
  display:flex;align-items:center;gap:6px;
}
.guide-col.ok h4{color:var(--sage-dark);}
.guide-col.avoid h4{color:var(--rose);}
.guide-col ul{margin:0;padding-left:0;list-style:none;font-size:13.5px;}
.guide-col li{padding:4px 0;border-top:1px solid var(--line);}
.guide-col li:first-of-type{border-top:none;}
.tip{
  background:var(--clay-tint);border-left:3px solid var(--clay);padding:12px 14px;
  border-radius:0 4px 4px 0;font-size:13.5px;margin-top:16px;
}

/* ---- Connection status ---- */
.conn-warning{
  background:var(--rose-tint);border-left:3px solid var(--rose);padding:10px 14px;
  border-radius:0 4px 4px 0;font-size:13px;margin-bottom:18px;display:none;
}
.conn-warning.show{display:block;}
