:root{
  --ground:#FAF6F1; --surface:#FFFFFF; --ink:#2B2330; --muted:#7C7079; --line:#ECE3DA;
  --brand:#8A3A66; --brand-soft:#F4E5EE;
  --good:#4E8D6E; --warn:#C98A2E; --miss:#C2553F; --miss-soft:#FBEDE9;
  --c-petitdej:#E8A33D; --c-plat:#9C3D6E; --c-salade:#5E8C6A;
  --radius:14px; --shadow:0 1px 2px rgba(43,35,48,.05), 0 8px 24px rgba(43,35,48,.06);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--ground);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}
.wrap{max-width:1040px;margin:0 auto;padding:0 20px 72px}
.hidden{display:none!important}

/* top bar */
.bar{position:sticky;top:0;z-index:20;background:rgba(250,246,241,.88);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.bar-in{max-width:1040px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:10px}
.logo{font-family:Georgia,"Times New Roman",serif;font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--brand)}
.logo .dot{color:var(--c-petitdej)}
.tag{font-size:12.5px;color:var(--muted)}
.tabs{display:flex;gap:4px;margin-left:auto;background:var(--brand-soft);padding:4px;border-radius:999px}
.tab{border:0;background:transparent;color:var(--brand);font:inherit;font-size:14px;font-weight:600;padding:8px 16px;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}
.tab[aria-selected="true"]{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.barlink{border:0;background:transparent;color:var(--muted);font:inherit;font-size:13px;cursor:pointer;padding:6px 8px;border-radius:8px}
.barlink:hover{color:var(--ink);background:var(--brand-soft)}

/* generic */
.view{display:none;animation:fade .25s ease}
.view.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.view{animation:none}}
h2.title{font-size:22px;letter-spacing:-.01em;margin:28px 0 4px}
.sub{color:var(--muted);font-size:14px;margin:0 0 20px;max-width:62ch}

.btn{border:0;border-radius:10px;font:inherit;font-weight:600;cursor:pointer;padding:11px 18px;display:inline-flex;align-items:center;gap:8px;transition:transform .08s,filter .15s}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover:not(:disabled){filter:brightness(1.07)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:#dccfe2}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:600;color:var(--muted)}
.field input,.field select{font:inherit;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus{outline:2px solid var(--brand);outline-offset:1px;border-color:transparent}

/* import / dropzone */
.drop{border:2px dashed #e0d3ca;border-radius:var(--radius);padding:42px 20px;text-align:center;background:var(--surface);cursor:pointer;transition:border-color .15s,background .15s}
.drop:hover,.drop.over{border-color:var(--brand);background:var(--brand-soft)}
.drop .big{font-size:38px;margin-bottom:8px}
.drop .hint{color:var(--muted);font-size:13px;margin-top:6px}
.import-status{margin:16px 0;font-size:14px}
.import-status.err{color:var(--miss)}

/* stock cards */
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:22px 0 14px}
.count{font-size:14px;color:var(--muted)}.count b{color:var(--ink)}
.form-inline{display:grid;grid-template-columns:1fr 190px 110px auto;gap:12px;align-items:end;padding:18px}
@media (max-width:680px){.form-inline{grid-template-columns:1fr 1fr}}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:12px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:9px}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.dish-name{font-weight:600;font-size:15px;line-height:1.3}
.qty-pill{font-variant-numeric:tabular-nums;font-weight:700;font-size:13px;background:var(--brand-soft);color:var(--brand);padding:3px 9px;border-radius:999px;white-space:nowrap}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 9px;border-radius:8px;width:fit-content}
.chip .swatch{width:9px;height:9px;border-radius:3px}
.card-foot{display:flex;align-items:center;gap:8px}
.slots-line{font-size:12px;color:var(--muted)}
.icon-btn{margin-left:auto;background:transparent;border:0;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:2px 6px;border-radius:6px}
.icon-btn:hover{color:var(--miss);background:var(--miss-soft)}

/* validation table */
.vtable{width:100%;border-collapse:collapse;font-size:14px}
.vtable th{text-align:left;font-size:12px;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line)}
.vtable td{padding:7px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.vtable input[type=text]{width:100%;font:inherit;padding:7px 9px;border:1px solid var(--line);border-radius:8px}
.vtable input[type=number]{width:64px;font:inherit;padding:7px 9px;border:1px solid var(--line);border-radius:8px}
.vtable select{font:inherit;padding:7px 9px;border:1px solid var(--line);border-radius:8px}
.tag-known{font-size:11px;color:var(--good);font-weight:600}
.tag-guess{font-size:11px;color:var(--warn);font-weight:600}

/* planning */
.plan-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:22px 0 16px}
.weeks{display:flex;gap:6px;flex-wrap:wrap}
.wbtn{border:1px solid var(--line);background:var(--surface);color:var(--ink);font:inherit;font-weight:600;font-size:13.5px;padding:8px 15px;border-radius:10px;cursor:pointer}
.wbtn[aria-selected="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.stats{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 13px;font-size:13px;display:flex;align-items:center;gap:8px}
.stat b{font-variant-numeric:tabular-nums}.stat .ic{width:8px;height:8px;border-radius:50%}
.gridwrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}
table.grid{border-collapse:collapse;width:100%;min-width:680px}
table.grid th,table.grid td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);padding:0}
table.grid th:last-child,table.grid td:last-child{border-right:0}
table.grid tr:last-child td{border-bottom:0}
.corner{background:var(--ground);width:128px}
thead th.day{background:var(--ground);font-size:13px;font-weight:700;padding:12px 10px;text-align:center}
th.slot{background:var(--ground);text-align:left;padding:12px 14px;font-size:13px;font-weight:600;white-space:nowrap}
th.slot small{display:block;font-weight:500;color:var(--muted);font-size:11px}
td.cell{padding:8px;vertical-align:top;height:74px}
.meal{height:100%;border-radius:10px;padding:9px 10px;display:flex;flex-direction:column;gap:6px;border-left:4px solid var(--cc);background:color-mix(in srgb, var(--cc) 9%, white)}
.meal .m-cat{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--cc)}
.meal .m-name{font-size:13px;font-weight:600;line-height:1.25}
.empty{height:100%;border:1.5px dashed #e2d6cf;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#b9aaa3;font-size:12px;font-weight:600}
.leftover{margin-top:22px}.leftover h3{font-size:15px;margin:0 0 10px}
.lo-list{display:flex;flex-wrap:wrap;gap:8px}
.lo{font-size:12.5px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 12px;display:flex;align-items:center;gap:7px}
.lo b{font-variant-numeric:tabular-nums}.lo.zero{opacity:.45}

.empty-state{text-align:center;padding:56px 20px;color:var(--muted)}
.empty-state .big{font-size:40px;margin-bottom:10px}

/* login / modal overlay */
.overlay{position:fixed;inset:0;z-index:50;background:rgba(43,35,48,.45);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 20px 60px rgba(43,35,48,.3);width:100%;max-width:380px;padding:28px}
.modal h2{margin:0 0 4px;font-size:20px}
.modal p.sub{margin-bottom:18px}
.modal .field{margin-bottom:14px}
.modal .err{color:var(--miss);font-size:13px;min-height:18px;margin-bottom:8px}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;box-shadow:var(--shadow);z-index:60;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-2px)}
.footer{display:flex;justify-content:center;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin-top:36px}
.linklike{background:none;border:0;color:var(--brand);font:inherit;font-size:12px;cursor:pointer;text-decoration:underline;padding:0}

/* modale large (changelog) */
.modal-wide{max-width:540px;max-height:84vh;display:flex;flex-direction:column}
#changelog-body{overflow-y:auto;margin-top:6px}
.cl-ver{margin-top:16px}
.cl-ver:first-child{margin-top:4px}
.cl-ver-title{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.03em;margin:0 0 8px}
.cl-sec-title{font-size:14px;margin:10px 0 6px}
.cl-items{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}
.cl-items li{font-size:14px;line-height:1.45}

/* édition d'une case du planning */
td.cell,.dayslot{cursor:pointer}
.cell.sel .meal,.cell.sel .empty,.dayslot.sel .meal,.dayslot.sel .empty{box-shadow:0 0 0 2px var(--brand) inset}
.cell.swapsrc .meal,.cell.swapsrc .empty,.dayslot.swapsrc .meal,.dayslot.swapsrc .empty{box-shadow:0 0 0 2px var(--c-petitdej) inset}
.cell-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.cell-actions .btn{flex:1;justify-content:center;white-space:nowrap}

/* ---------- impression du menu ---------- */
#print-area{display:none}
.print-opt{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;user-select:none}
.print-opt input{width:16px;height:16px;accent-color:var(--brand)}
@media print{
  body{background:#fff}
  .bar,.wrap,.overlay,.toast{display:none!important}
  #print-area{display:block}
  @page{margin:14mm}
  .print-doc{color:#000;font-family:var(--font)}
  .print-doc h1{font-size:18pt;margin:0 0 5mm}
  .print-doc h2{font-size:12pt;margin:7mm 0 2mm;page-break-after:avoid}
  .ptable{width:100%;border-collapse:collapse;margin-bottom:4mm;page-break-inside:avoid}
  /* print-color-adjust:exact → conserve les fonds/bordures couleur en mode « En couleur » */
  .ptable th,.ptable td{border:1px solid #888;padding:2mm;font-size:9pt;text-align:left;vertical-align:top;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .ptable thead th{background:#eee;text-align:center}
  .ptable tbody th{width:22mm;font-weight:600}
  .pc{display:block;font-size:6.5pt;color:#555;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5mm}
  .pe{color:#aaa}
}

/* ---------- planning : cartes par jour (mobile) ---------- */
/* Rendu en plus de la table desktop ; CSS bascule l'un ou l'autre selon la
   largeur (cf. media query). La table (slots×jours) scrollerait mal sur tel. */
.plan-mobile{display:none;flex-direction:column;gap:12px}
.daycard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.daycard h4{margin:0 0 12px;font-size:15px;letter-spacing:-.01em}
.dayslot{display:grid;grid-template-columns:74px 1fr;gap:10px;margin-bottom:8px}
.dayslot:last-child{margin-bottom:0}
.ds-label{font-size:12px;font-weight:600;color:var(--muted);align-self:center}
.dayslot .meal,.dayslot .empty{min-height:48px}

/* ---------- responsive mobile ---------- */
@media (max-width:600px){
  .wrap{padding:0 13px 84px}
  .bar-in{padding:10px 13px;gap:8px 10px}
  .logo{font-size:21px}
  .tag{display:none}                              /* tagline cachée sur mobile */
  .barlink{order:1;margin-left:auto}              /* déconnexion à droite, ligne 1 */
  .tabs{order:2;flex-basis:100%;margin-left:0;justify-content:space-between} /* onglets pleine largeur, ligne 2 */
  .tab{flex:1;text-align:center;justify-content:center;padding:9px 6px;font-size:13px}
  h2.title{font-size:19px;margin-top:20px}
  .sub{font-size:13.5px}

  .form-inline{grid-template-columns:1fr 1fr;padding:14px;gap:10px}
  .form-inline .field{min-width:0}                     /* colonnes 1fr réellement égales */
  .form-inline .field:nth-child(1){grid-column:1/-1}   /* nom pleine largeur */
  .form-inline .field:nth-child(4){grid-column:1/-1}   /* bouton pleine largeur */
  .form-inline .btn{width:100%;justify-content:center}

  .toolbar{gap:8px}
  .toolbar .count{flex-basis:100%}
  /* boutons d'action empiles pleine largeur (sinon "Importer une facture" passe
     sur 2-3 lignes a flex:1 ~168px) */
  .toolbar .btn{flex-basis:100%;justify-content:center;margin-left:0!important}

  .cards{grid-template-columns:1fr}              /* 1 carte par ligne */

  .plan-head{gap:12px}
  .stats{margin-left:0;flex-basis:100%}
  .stat{flex:1;justify-content:center}
  .weeks{flex-basis:100%}
  .wbtn{flex:1;text-align:center;padding:9px 4px;font-size:13px}

  .gridwrap{display:none}                        /* table desktop masquée */
  .plan-mobile{display:flex}                      /* cartes par jour affichées */

  .drop{padding:30px 14px}
  .modal{padding:22px}
}
