:root{
  --paper:#FBFAF5;--ink:#1F2A24;--muted:#6B7570;--line:#E7E3D8;--card:#FFFFFF;
  --bk:#E8902A;--bk-bg:#FBEDD7;--lu:#2C8FB0;--lu-bg:#E2EFF4;--di:#2F8F5B;--di-bg:#E4F2E9;
  --gui:#F0851F;--naz:#ED6AA0;--volaille:#DD6B36;--poisson:#2C8FB0;--veg:#2F8F5B;--oeufs:#E0A92A;
  --shadow:0 1px 0 rgba(31,42,36,.04),0 10px 26px -18px rgba(31,42,36,.30);
}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:18px 18px 70px}
h1,h2,h3{font-family:"Bricolage Grotesque",system-ui,sans-serif;font-weight:800;letter-spacing:-.01em;margin:0}
.mono{font-family:"DM Mono","SFMono-Regular",ui-monospace,monospace}

/* ---- TOP NAV ---- */
.topnav{display:flex;align-items:center;gap:8px;padding:10px 0 14px;border-bottom:2px solid var(--ink);margin-bottom:18px;flex-wrap:wrap}
.topnav .brand{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:15px;margin-right:6px}
.topnav a{text-decoration:none;font-weight:650;font-size:13.5px;color:var(--ink);border:1px solid var(--line);background:var(--card);border-radius:999px;padding:7px 14px;transition:.15s}
.topnav a:hover{border-color:var(--di);color:var(--di)}
.topnav a.active{background:var(--ink);color:#F3F1E9;border-color:var(--ink)}
.topnav .sp{margin-left:auto}
.btn{font-family:"Inter",sans-serif;font-weight:650;font-size:13px;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:999px;padding:8px 14px;cursor:pointer;transition:.15s}
.btn:hover{border-color:var(--di);color:var(--di)}
.btn.solid{background:var(--di);color:#fff;border-color:var(--di)}.btn.solid:hover{filter:brightness(1.05);color:#fff}
.btn.warn{border-color:#E3B7B0;color:#A8503F}.btn.warn:hover{background:#FBEEEB}

/* ---- HERO ---- */
.hero{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px 22px}
.hero .kicker{font-family:"DM Mono",monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--di);font-weight:500}
.hero h1{font-size:clamp(26px,4.2vw,42px);line-height:1.02}
.hero .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:999px;border:1px solid var(--line);background:var(--card)}
.swatch{width:11px;height:11px;border-radius:3px;display:inline-block}.dot{width:13px;height:13px;border-radius:999px;display:inline-block}.sep{width:1px;height:18px;background:var(--line)}
.lead{margin:14px 0 0;color:var(--muted);max-width:64ch}
.legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin:16px 0 0;align-items:center}

.how{margin:20px 0 0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.how .c{background:var(--di-bg);border:1px solid #CFE6D7;border-radius:14px;padding:13px 15px}
.how .c .n{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:14.5px;display:flex;align-items:center;gap:9px;margin-bottom:4px;color:#1C5C3C}
.how .c .em{font-size:18px}.how .c p{margin:0;font-size:13px;color:#2B4738}
.how .c p .en{display:block;color:#6E8A7B;font-style:italic;margin-top:2px}

/* ---- TODAY ---- */
.today{margin-top:24px;background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.today .bar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--ink);color:#F3F1E9;flex-wrap:wrap}
.today .bar .ttl{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:16px}
.today .bar .nav{margin-left:auto;display:flex;gap:6px;align-items:center}
.today .bar .nav button{background:#2C3A33;color:#F3F1E9;border:1px solid #3A4A42;border-radius:9px;width:34px;height:32px;font-size:16px;cursor:pointer}
.today .bar .nav button:hover{background:#37463E}
.today .bar .nav .now{width:auto;padding:0 12px;font-size:12.5px;font-weight:650;font-family:"Inter",sans-serif}
.today .action{display:flex;gap:11px;align-items:flex-start;padding:13px 16px;background:var(--di-bg);border-bottom:1px solid #CFE6D7}
.today .action .ic{font-size:22px;line-height:1}.today .action .tx{font-size:14px;color:#1C5C3C}.today .action .tx b{color:#15512f}
.today .action .tx .sub{display:block;color:#3f6b53;font-size:12.5px;margin-top:3px}
.nutri{display:flex;gap:8px;flex-wrap:wrap;padding:10px 16px;border-bottom:1px solid var(--line);background:#FCFBF6;font-size:12.5px}
.nutri .pill{font-family:"DM Mono",monospace;border:1px solid var(--line);border-radius:999px;padding:3px 10px;background:#fff}
.nutri .pill b{color:var(--ink)}
.today .meals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}
.strip{display:flex;gap:7px;overflow-x:auto;padding:12px 16px;border-top:1px solid var(--line);background:#FCFBF6}
.strip::-webkit-scrollbar{height:7px}.strip::-webkit-scrollbar-thumb{background:#DCD8CC;border-radius:9px}
.strip .d{flex:0 0 auto;min-width:60px;text-align:center;border:1px solid var(--line);background:#fff;border-radius:12px;padding:7px 9px;cursor:pointer}
.strip .d:hover{border-color:var(--di)}.strip .d.active{background:var(--ink);color:#F3F1E9;border-color:var(--ink)}
.strip .d.today{outline:2px solid var(--gui);outline-offset:1px}
.strip .d .w{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:13px}.strip .d .n{font-family:"DM Mono",monospace;font-size:10.5px;opacity:.75}

/* ---- MEAL CARD ---- */
.meal{position:relative;background:var(--card);border:1px solid var(--line);border-left-width:4px;border-radius:14px;padding:9px 12px 10px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:.12s}
.meal:hover{transform:translateY(-1px)}
.meal:after{content:"voir la recette ›";position:absolute;right:11px;bottom:9px;font-size:10.5px;color:var(--muted);opacity:0}
.meal:hover:after{opacity:.9}
.meal.bk{border-left-color:var(--bk);background:linear-gradient(180deg,var(--bk-bg),#fff 62%)}
.meal.lu{border-left-color:var(--lu);background:linear-gradient(180deg,var(--lu-bg),#fff 62%)}
.meal.di{border-left-color:var(--di);background:linear-gradient(180deg,var(--di-bg),#fff 58%)}
.meal .ml{font-family:"DM Mono",monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.meal .dish{font-weight:650;font-size:13.5px;line-height:1.3}.meal .dish .lo{color:var(--muted);font-weight:500;font-style:italic}
.meal .en{color:var(--muted);font-style:italic;font-size:12px;line-height:1.3}
.meal .who{display:flex;gap:6px;align-items:flex-start;margin-top:1px}
.meal .who .tagp{font-family:"DM Mono",monospace;font-weight:600;font-size:11px;color:#fff;border-radius:6px;padding:1px 6px;line-height:1.5;flex-shrink:0;margin-top:1px}
.tagp.g{background:var(--gui)}.tagp.n{background:var(--naz)}.meal .who .txt{font-size:12.5px}
.badge{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:11px;padding:3px 9px;border-radius:999px}
.b-cook{background:var(--di);color:#fff}.b-exp{background:#DCEFE3;color:#1C5C3C;border:1px solid #BfE0CD}
.b-rest{background:#EFEDE6;color:#7A7468;border:1px solid var(--line)}.b-ass{background:#F4F1E8;color:#8A8472;border:1px solid var(--line)}
.ref{margin-left:auto;font-family:"DM Mono",monospace;font-weight:600;font-size:11px;color:var(--di);border:1px dashed #9CCBB0;border-radius:7px;padding:2px 7px}
.badge-row{display:flex;align-items:center;gap:6px;margin-top:auto;padding-top:4px;flex-wrap:wrap}
.cook-flag{font-size:11px;font-weight:700;border-radius:999px;padding:2px 8px}
.cf-ok{background:var(--di-bg);color:#1C5C3C}.cf-no{background:#FCE9CE;color:#8A5B1E}

/* ---- SECTIONS ---- */
.sect{margin-top:34px}
.sect-h{display:flex;align-items:baseline;gap:13px;margin-bottom:6px}
.sect-h h2{font-size:22px}.sect-h .rule{flex:1;height:2px;background:var(--line);border-radius:2px}
.sect .hint{color:var(--muted);font-size:13px;margin:0 0 14px}
.day{display:grid;grid-template-columns:118px repeat(3,1fr);gap:10px;margin-bottom:10px;align-items:stretch}
.day-label{display:flex;flex-direction:column;justify-content:center;padding:10px 12px;background:var(--ink);color:#F3F1E9;border-radius:14px}
.day-label .wd{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:17px}.day-label .dt{font-family:"DM Mono",monospace;font-size:11.5px;opacity:.72;margin-top:2px}
.week-tag{font-family:"DM Mono",monospace;font-size:12.5px;color:var(--muted);margin:18px 0 8px}

/* ---- STOCK ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:16px 18px}
.tools{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px;align-items:center}
.tools select{font-family:"Inter",sans-serif;font-size:13px;border:1px solid var(--line);border-radius:10px;padding:7px 10px;background:#fff}
.rayon{margin-top:14px}
.rayon h4{font-family:"DM Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;display:flex;align-items:center;gap:8px}
.rayon h4:after{content:"";flex:1;height:1px;background:var(--line)}
.stockrow{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px dashed #EEEADD}
.stockrow .nm{flex:1;font-size:13.5px}
.stockrow .have0{color:#C0392B}
.stepper{display:flex;align-items:center;gap:4px}
.stepper button{width:28px;height:28px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:15px;cursor:pointer;color:var(--ink)}
.stepper button:hover{border-color:var(--di);color:var(--di)}
.stepper input{width:64px;text-align:center;font-family:"DM Mono",monospace;font-size:13px;border:1px solid var(--line);border-radius:8px;padding:5px 4px}
.stepper .un{font-family:"DM Mono",monospace;font-size:11px;color:var(--muted);min-width:42px}

/* ---- SHOPPING ---- */
.shop{margin-top:12px}
.shoprayon{margin-bottom:10px}
.shoprayon h4{font-family:"DM Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 6px}
.buyrow{display:flex;align-items:center;gap:9px;padding:6px 10px;border:1px solid var(--line);border-radius:11px;margin-bottom:6px;background:#fff}
.buyrow input{accent-color:var(--di);width:17px;height:17px}
.buyrow.checked{background:var(--di-bg);border-color:#9CCBB0}.buyrow.checked .lab{text-decoration:line-through;color:#5A6A60}
.buyrow .lab{flex:1;font-size:13.5px}.buyrow .q{font-family:"DM Mono",monospace;font-size:12px;color:var(--muted)}
.cond-note{margin-top:8px;font-size:12.5px;color:var(--muted);background:#FCFBF6;border:1px dashed var(--line);border-radius:11px;padding:9px 12px}

/* ---- AVAILABILITY LIST ---- */
.avlist .r{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line);border-radius:12px;margin-bottom:7px;cursor:pointer;background:#fff;transition:.12s}
.avlist .r:hover{border-color:var(--di);transform:translateX(2px)}
.avlist .r .tag{font-family:"DM Mono",monospace;font-size:11px;font-weight:600;color:#fff;border-radius:7px;padding:2px 7px}
.avlist .r .nm{font-weight:600;font-size:13.5px;flex:1}
.avlist .r .st{font-size:11.5px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.st.ok{background:var(--di-bg);color:#1C5C3C}.st.miss{background:#FCE9CE;color:#8A5B1E}

/* ---- MODAL ---- */
.overlay{position:fixed;inset:0;background:rgba(20,27,23,.55);display:none;align-items:center;justify-content:center;padding:18px;z-index:50}
.overlay.open{display:flex}
.modal{background:var(--paper);border-radius:20px;max-width:660px;width:100%;max-height:88vh;overflow:auto;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
.modal .mtop{padding:16px 20px;color:#fff;position:sticky;top:0;display:flex;align-items:flex-start;gap:12px;z-index:1}
.modal .mtop.volaille{background:var(--volaille)}.modal .mtop.poisson{background:var(--poisson)}.modal .mtop.veg{background:var(--veg)}.modal .mtop.oeufs{background:var(--oeufs)}
.modal .mtop.petit-dej{background:var(--bk)}.modal .mtop.dejeuner{background:var(--lu)}
.modal .mtop .rid{font-family:"DM Mono",monospace;font-size:12px;font-weight:600;opacity:.92}
.modal .mtop h3{font-size:19px;line-height:1.13}.modal .mtop h3 .en{display:block;font-family:"Inter",sans-serif;font-weight:500;font-style:italic;font-size:13px;opacity:.93;margin-top:2px}
.modal .mtop .x{margin-left:auto;background:rgba(255,255,255,.2);border:none;color:#fff;width:32px;height:32px;border-radius:9px;font-size:18px;cursor:pointer;flex-shrink:0}
.modal .mbody{padding:16px 20px 22px}
.avbox{border-radius:11px;padding:9px 12px;font-size:13px;margin-bottom:12px;font-weight:600}
.avbox.ok{background:var(--di-bg);color:#1C5C3C;border:1px solid #9CCBB0}.avbox.miss{background:#FCE9CE;color:#8A5B1E;border:1px solid #EAC58C}
.lo-note{background:#EFEDE6;border:1px solid var(--line);border-radius:11px;padding:9px 12px;font-size:13px;color:#5A6A60;margin-bottom:12px}
.meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.meta span{font-family:"DM Mono",monospace;font-size:11.5px;color:var(--muted);background:#F6F4EC;border:1px solid var(--line);border-radius:999px;padding:3px 10px}
.meta .kcal{background:#FBEDD7;color:#8A5B1E;border-color:#EAC58C}
.modal h4{font-family:"DM Mono",monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin:14px 0 7px;font-weight:600}
.modal ul{margin:0;padding-left:17px}.modal ul li{font-size:13.5px;margin-bottom:4px}.modal ul li.cnd{color:var(--muted);font-style:italic;list-style:none;margin-left:-17px}
.modal ol{margin:0;padding-left:0;list-style:none;counter-reset:s}
.modal ol li{font-size:13.5px;margin-bottom:8px;line-height:1.42;padding-left:34px;position:relative;cursor:pointer}
.modal ol li:before{counter-increment:s;content:counter(s);position:absolute;left:0;top:0;width:23px;height:23px;border-radius:999px;background:var(--di);color:#fff;font-family:"DM Mono",monospace;font-size:12px;display:flex;align-items:center;justify-content:center;font-weight:600}
.modal ol li.done{color:var(--muted);text-decoration:line-through}.modal ol li .en{display:block;color:var(--muted);font-style:italic;font-size:12px;margin-top:1px;text-decoration:none}
.mactions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);align-items:center}
.rate{display:flex;gap:6px;margin-left:auto;align-items:center}
.rate .rb{border:1px solid var(--line);background:#fff;border-radius:10px;padding:6px 10px;cursor:pointer;font-size:15px}
.rate .rb.on-love{background:#FDE7EF;border-color:var(--naz)}.rate .rb.on-no{background:#EFEDE6;border-color:#bbb}

/* ---- TOAST ---- */
.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#F3F1E9;padding:11px 18px;border-radius:12px;font-size:13.5px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:60;box-shadow:0 14px 30px -12px rgba(0,0,0,.5)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- FOOTER ---- */
.foot{margin-top:42px;border-top:2px solid var(--ink);padding-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.foot .f .h{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:14px;margin-bottom:5px;display:flex;gap:8px;align-items:center}
.foot .f p{margin:0;color:var(--muted);font-size:13px}.foot .f p .en{font-style:italic}

@media (max-width:880px){
  .how{grid-template-columns:1fr}.today .meals{grid-template-columns:1fr}
  .day{grid-template-columns:1fr;gap:7px;margin-bottom:16px;border:1px solid var(--line);border-radius:16px;padding:8px;background:#fff}
  .day-label{flex-direction:row;align-items:center;gap:10px;border-radius:11px}.day-label .dt{margin-top:0}
  .meal{box-shadow:none}.foot{grid-template-columns:1fr}
}
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body{font-size:11px}.wrap{max-width:none;padding:0}
  .topnav,.hero .right,.today .bar .nav,.strip,.tools,.btn,.stepper button,.mactions{display:none!important}
  .sect{break-before:page}.day,.meal,.panel{break-inside:avoid}
}

/* ===== D1 / sync badge ===== */
#syncbadge{font-family:"DM Mono",monospace;font-size:11.5px;color:#1C5C3C;background:var(--di-bg);border:1px solid #9CCBB0;border-radius:999px;padding:5px 10px;font-weight:600}
#syncbadge.local{color:#8A5B1E;background:#FCE9CE;border-color:#EAC58C}

/* ===== portion scaler (modal) ===== */
.scaler{display:flex;align-items:center;gap:8px;margin:4px 0 2px;font-size:13px}
.scaler span{color:var(--muted)}
.scaler button{width:28px;height:28px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:15px;cursor:pointer;color:var(--ink)}
.scaler button:hover{border-color:var(--di);color:var(--di)}
.scaler b{font-family:"DM Mono",monospace;font-size:15px;min-width:22px;text-align:center}
.scaler .base{font-size:11.5px;font-style:italic}

/* ===== constraints note ===== */
.constraints{margin-top:14px;font-size:12.5px;color:#8A5B1E;background:#FCF3E4;border:1px solid #EAD9B8;border-radius:11px;padding:9px 12px}
.constraints b{color:#6E4818}

/* ===== recettes page ===== */
.searchbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.searchbar input{flex:1;min-width:200px;font-family:"Inter",sans-serif;font-size:14px;border:1px solid var(--line);border-radius:11px;padding:9px 12px;background:#fff}
.fchips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.fchip{font-size:12.5px;font-weight:600;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;cursor:pointer;transition:.12s}
.fchip:hover{border-color:var(--di)}
.fchip.on{background:var(--ink);color:#F3F1E9;border-color:var(--ink)}
.reclist{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.reccard{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:11px 13px;cursor:pointer;box-shadow:var(--shadow);transition:.12s}
.reccard:hover{transform:translateY(-1px);border-color:var(--di)}
.reccard .tag{font-family:"DM Mono",monospace;font-size:11px;font-weight:600;color:#fff;border-radius:7px;padding:2px 7px;flex-shrink:0}
.reccard .rc-main{flex:1;min-width:0}
.reccard .rc-name{font-weight:650;font-size:14px;line-height:1.25}
.reccard .rc-en{color:var(--muted);font-style:italic;font-size:12px;line-height:1.25}
.reccard .rc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:1px;font-family:"DM Mono",monospace;font-size:10.5px;color:var(--muted);white-space:nowrap}
@media (max-width:880px){ .reclist{grid-template-columns:1fr} }
