:root{
  --ink:#12110f;--ink2:#1c1a17;--paper:#f5efe4;--paper2:#ebe1d0;--white:#fffdf9;
  --gold:#bf8734;--gold-soft:#f5e4bf;--sage:#2b6d54;--sage-soft:#dceee3;
  --red:#9d382d;--red-soft:#f7dfdb;--orange:#a96918;--orange-soft:#f7e6c9;
  --muted:#7d766d;--line:#ded3c2;--shadow:0 16px 50px rgba(25,20,13,.12);
  --radius:20px;--radius-sm:13px;
}
*{box-sizing:border-box}
html{background:var(--paper);min-height:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;min-height:100vh}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
button:disabled{opacity:.52;cursor:not-allowed}
a{color:inherit}
.splash{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-size:15px}
.app{min-height:100vh;padding-bottom:88px}
.topbar{position:sticky;top:0;z-index:20;background:rgba(245,239,228,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(222,211,194,.8)}
.topbar-inner{max-width:1280px;margin:0 auto;padding:13px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand-mark{width:35px;height:35px;border-radius:11px;background:var(--ink);color:var(--gold);display:grid;place-items:center;font-family:Georgia,serif;font-weight:800;font-size:20px;box-shadow:0 6px 14px rgba(0,0,0,.15)}
.brand b{display:block;font-size:14px;letter-spacing:-.01em}.brand small{display:block;color:var(--muted);font-size:11px;margin-top:1px}
.top-controls{display:flex;align-items:center;gap:8px}.date-picker{border:1px solid var(--line);border-radius:10px;padding:8px;background:var(--white);font-size:13px;color:var(--ink)}.avatar{border:0;background:var(--ink);color:#fff;width:34px;height:34px;border-radius:50%;font-weight:800}
.main{max-width:1280px;margin:0 auto;padding:22px 18px 34px}
.eyebrow{color:var(--gold);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.page-title{margin:4px 0 0;font-size:27px;letter-spacing:-.045em}.page-intro{margin:8px 0 0;color:var(--muted);line-height:1.45;font-size:14px}
.dashboard-heading{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:18px}.today-label{color:var(--muted);font-size:13px;font-weight:700}
.card{background:var(--white);border:1px solid rgba(222,211,194,.9);border-radius:var(--radius);box-shadow:0 4px 14px rgba(25,20,13,.035)}
.card-pad{padding:18px}.grid{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-main{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(320px,.9fr);gap:18px}
.hero{background:linear-gradient(135deg,#181612 0%,#2a241b 100%);color:#fff;border:none;box-shadow:0 16px 40px rgba(25,20,13,.2);overflow:hidden;position:relative}.hero:after{content:"";position:absolute;width:250px;height:250px;border:1px solid rgba(191,135,52,.32);border-radius:50%;right:-90px;top:-130px}.hero .card-pad{position:relative;z-index:1}.hero .eyebrow{color:#e6bb72}.hero h2{margin:5px 0 7px;font-size:24px;letter-spacing:-.04em}.hero p{margin:0;color:#e5ddd0;max-width:640px;line-height:1.45;font-size:14px}
.metric{padding:15px}.metric .metric-label{font-size:12px;color:var(--muted);font-weight:750}.metric strong{display:block;font-size:23px;margin-top:6px;letter-spacing:-.045em}.metric small{display:block;color:var(--muted);margin-top:3px;font-size:11px}
.service-card{padding:16px;position:relative;overflow:hidden}.service-top{display:flex;justify-content:space-between;align-items:center;gap:8px}.service-name{font-weight:850}.service-meta{display:flex;gap:14px;margin:13px 0;color:var(--muted);font-size:12px}.service-meta b{display:block;color:var(--ink);font-size:15px;margin-bottom:2px}.team-chips{display:flex;flex-wrap:wrap;gap:5px}.team-chip{font-size:11px;background:var(--paper);padding:5px 8px;border-radius:20px;color:#4d4740}
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:800;white-space:nowrap}.badge:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.badge.vert{background:var(--sage-soft);color:var(--sage)}.badge.orange{background:var(--orange-soft);color:var(--orange)}.badge.rouge{background:var(--red-soft);color:var(--red)}.badge.neutral{background:var(--paper2);color:#625a50}.badge.sansdot:before{display:none}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:22px 0 10px}.section-head h2{font-size:16px;margin:0;letter-spacing:-.02em}.section-head a,.link-btn{color:var(--gold);font-size:12px;font-weight:800;text-decoration:none;border:0;background:transparent;padding:0}
.priority-list,.list{display:grid;gap:8px}.priority{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}.priority:last-child{border-bottom:0}.priority-mark{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto}.priority-mark.rouge{background:var(--red)}.priority-mark.orange{background:var(--orange)}.priority-mark.vert{background:var(--sage)}.priority b{font-size:13px;display:block}.priority span{font-size:12px;color:var(--muted);line-height:1.4;display:block;margin-top:2px}
.alert-row{display:flex;gap:10px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line)}.alert-row:last-child{border-bottom:0}.alert-icon{font-size:18px;line-height:1}.alert-row b{font-size:13px}.alert-row p{font-size:12px;color:var(--muted);margin:2px 0 0;line-height:1.35}
.empty{padding:22px 8px;color:var(--muted);font-size:13px;text-align:center}.empty .empty-icon{font-size:24px;margin-bottom:6px}
.quick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.quick{border:1px solid var(--line);background:var(--white);border-radius:12px;padding:11px 8px;text-align:left;min-height:73px}.quick:hover{border-color:var(--gold)}.quick span{display:block;font-size:18px;margin-bottom:4px}.quick b{display:block;font-size:11px;line-height:1.2}
.nav{position:fixed;z-index:30;left:0;right:0;bottom:0;background:rgba(18,17,15,.97);padding:8px max(12px,env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));display:flex;justify-content:center;gap:2px;box-shadow:0 -8px 26px rgba(0,0,0,.16)}.nav-inner{display:flex;width:min(700px,100%);justify-content:space-between}.nav-btn{border:0;background:transparent;color:#a8a197;min-width:56px;padding:5px 3px;font-size:9px;font-weight:700;display:grid;place-items:center;gap:3px}.nav-btn .nav-icon{font-size:19px;line-height:1}.nav-btn.active{color:var(--gold)}
.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.btn{border:0;border-radius:11px;padding:10px 13px;font-size:12px;font-weight:820;background:var(--ink);color:#fff}.btn.gold{background:var(--gold);color:#1d170d}.btn.light{background:var(--paper2);color:var(--ink)}.btn.danger{background:var(--red);color:#fff}.btn.small{padding:7px 9px;font-size:11px}.btn.full{width:100%}
.form-card{padding:18px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:grid;gap:5px}.field.full{grid-column:1/-1}.field label{font-size:11px;color:#615a51;font-weight:830;text-transform:uppercase;letter-spacing:.06em}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 11px;color:var(--ink);outline:0}.field textarea{min-height:83px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(191,135,52,.14)}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:13px}
.checklist-group{margin-bottom:15px}.checklist-title{font-size:12px;color:var(--muted);font-weight:850;text-transform:uppercase;letter-spacing:.08em;margin:0 0 7px}.check-row{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding:11px 0}.check-row:last-child{border-bottom:0}.check-toggle{width:23px;height:23px;appearance:none;border:1.5px solid #b8ada0;border-radius:8px;background:#fff;display:grid;place-items:center;flex:0 0 auto}.check-toggle:checked{background:var(--sage);border-color:var(--sage)}.check-toggle:checked:after{content:"✓";color:#fff;font-size:14px;font-weight:900}.check-label{flex:1;font-size:13px;line-height:1.3}.check-done .check-label{text-decoration:line-through;color:var(--muted)}.check-author{font-size:10px;color:var(--muted);max-width:100px;text-align:right}
.progress{height:7px;background:var(--paper2);border-radius:99px;overflow:hidden}.progress>span{height:100%;display:block;background:var(--sage);border-radius:99px;transition:width .25s ease}
.stock-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}.stock-row:last-child{border-bottom:0}.stock-name{font-weight:800;font-size:13px}.stock-meta{font-size:11px;color:var(--muted);margin-top:2px}.stock-qty{text-align:right;font-weight:900;font-size:14px}.stock-qty small{display:block;color:var(--muted);font-size:10px;font-weight:600}.stock-row.critical .stock-qty{color:var(--red)}.stock-actions{display:flex;gap:5px}.icon-btn{border:1px solid var(--line);background:#fff;border-radius:8px;width:29px;height:29px;font-size:15px}.icon-btn:hover{border-color:var(--gold)}
.log-row{padding:13px 0;border-bottom:1px solid var(--line)}.log-row:last-child{border-bottom:0}.log-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.log-head b{font-size:13px}.log-row p{font-size:13px;margin:5px 0;color:#4f4941;line-height:1.45}.log-meta{font-size:11px;color:var(--muted)}
.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px}.report-stat{padding:12px;border:1px solid var(--line);border-radius:12px}.report-stat small{font-size:10px;color:var(--muted);font-weight:750}.report-stat strong{display:block;margin-top:4px;font-size:17px;letter-spacing:-.04em}
.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;min-width:600px}.table th,.table td{padding:11px;border-bottom:1px solid var(--line);text-align:left;font-size:12px}.table th{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-size:10px}.table td b{font-size:13px}
.login-page{min-height:100vh;background:radial-gradient(circle at 90% 10%,#5a452a 0,transparent 32%),var(--ink);display:grid;place-items:center;padding:20px}.login-card{width:min(430px,100%);background:var(--paper);padding:30px;border-radius:25px;box-shadow:0 25px 90px #0009}.login-card .brand-mark{width:50px;height:50px;border-radius:15px;font-size:27px}.login-card h1{font-size:27px;letter-spacing:-.05em;margin:20px 0 6px}.login-card p{color:var(--muted);font-size:14px;margin:0 0 18px;line-height:1.45}.login-card .btn{margin-top:8px}.login-note{font-size:11px;color:var(--muted);margin-top:14px!important}
.toast{position:fixed;left:50%;bottom:98px;z-index:100;transform:translate(-50%,18px);opacity:0;background:var(--ink);color:#fff;padding:11px 14px;border-radius:11px;box-shadow:0 12px 30px #0005;transition:.24s;pointer-events:none;font-size:12px;font-weight:700;max-width:calc(100vw - 30px);text-align:center}.toast.show{opacity:1;transform:translate(-50%,0)}
@media(min-width:820px){.app{padding-bottom:0}.nav{position:sticky;top:66px;bottom:auto;float:left;width:194px;height:calc(100vh - 66px);padding:14px;background:var(--ink);display:block;box-shadow:none}.nav-inner{display:grid;width:100%;gap:3px}.nav-btn{width:100%;grid-template-columns:24px 1fr;place-items:center start;text-align:left;padding:10px 11px;border-radius:10px;font-size:12px;color:#b8b0a5}.nav-btn .nav-icon{font-size:17px}.nav-btn.active{background:#2a251e;color:var(--gold)}.main{margin-left:194px;max-width:calc(1280px + 194px);padding:28px 28px 42px}.topbar-inner{padding-left:222px}.toast{bottom:24px}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:819px){.grid-main{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr}.dashboard-heading{align-items:flex-start;flex-direction:column}.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:450px){.main{padding:18px 13px 28px}.topbar-inner{padding:11px 13px}.brand small{display:none}.page-title{font-size:24px}.card-pad,.form-card{padding:15px}.grid-2,.form-grid,.form-grid.three{grid-template-columns:1fr}.form-grid .field.full{grid-column:auto}.service-meta{gap:16px}.quick{min-height:67px}.nav-btn{min-width:48px}.nav-btn:nth-child(6){display:none}.top-controls .date-picker{width:124px}.stock-row{grid-template-columns:minmax(0,1fr) auto}.stock-actions{grid-column:2;justify-content:flex-end}.check-author{display:none}}

.inventory-banner{margin-top:14px;padding:15px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-color:#ead6ad;background:#fff9ec}.inventory-banner b{display:block;margin-top:4px;font-size:17px}.inventory-banner p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.35}.catalog-intro{margin-bottom:18px;color:#5c4b34;font-size:13px;line-height:1.45;background:#fff9ec;border-color:#ead6ad}.catalog-group{margin-top:20px}.catalog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.catalog-card{padding:15px}.catalog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.catalog-head h3{font-size:15px;margin:0;letter-spacing:-.02em}.catalog-head p{margin:4px 0 0;font-size:11px;line-height:1.35;color:var(--muted)}.catalog-head>b{font-size:12px;white-space:nowrap;color:#70501d}.ingredient-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:12px}.ingredient-chip{padding:5px 7px;border-radius:8px;font-size:10px;line-height:1.2;background:var(--paper2);color:#554d44}.ingredient-chip.verified{background:var(--sage-soft);color:#296047}.ingredient-chip.pending{background:var(--orange-soft);color:#8d5d16}.ingredient-chip small{display:block;margin-top:2px;opacity:.78;font-size:9px}.catalog-flag,.catalog-note{margin-top:10px;padding:8px 9px;border-radius:8px;background:var(--orange-soft);color:#875914;font-size:10px;line-height:1.35}.catalog-note{background:var(--paper2);color:#625a50}
@media(max-width:819px){.catalog-grid{grid-template-columns:1fr}.inventory-banner{align-items:flex-start;flex-direction:column}.inventory-banner .btn{width:100%}}
/* V1.2 — Service Fiable */
.top-icon{width:34px;height:34px;border:1px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink);font-size:17px;font-weight:800}.top-icon:hover{border-color:var(--gold)}
.check-label em{display:block;font-style:normal;color:var(--muted);font-size:10px;margin-top:2px}.roster-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}.roster-row:last-child{border-bottom:0}.roster-row b{display:block;font-size:13px}.roster-row small{display:block;font-size:11px;color:var(--muted);margin-top:2px}.roster-row>div:last-child{display:flex;align-items:center;gap:7px;text-align:right}.resolution-note{font-size:12px!important;color:#2d6248!important;background:var(--sage-soft);border-radius:8px;padding:8px 9px}.variance-field{border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:var(--paper2)}.variance-field label{margin-bottom:2px}.variance-value{font-size:18px;letter-spacing:-.03em}.variance-value.good{color:#2d7351}.variance-value.bad{color:var(--red)}
@media(max-width:450px){.top-icon{display:none}.roster-row{align-items:flex-start}.roster-row>div:last-child{align-items:flex-end;flex-direction:column}.nav-btn:nth-child(6){display:grid}}
/* V1.3 — Marge & Commandes */
.order-card{border-left:3px solid var(--gold)}.order-lines{margin-top:10px}.order-line-read{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:12px}.order-line-read:last-child{border-bottom:0}.order-line-read span{font-weight:700;min-width:0}.order-line-read b{text-align:right;font-size:12px}.order-line-read small{grid-column:1/-1;color:var(--muted);font-size:10px;margin-top:-5px}.order-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:12px;padding-top:11px;border-top:1px solid var(--line);font-size:11px;color:var(--muted)}.order-picker{border:1px solid var(--line);border-radius:11px;margin:13px 0;max-height:330px;overflow:auto;background:#fff}.order-pick{display:grid;grid-template-columns:auto minmax(0,1fr) 70px 34px;gap:8px;align-items:center;padding:10px;border-bottom:1px solid var(--line)}.order-pick:last-child{border-bottom:0}.order-pick input[type="checkbox"]{width:18px;height:18px;accent-color:var(--gold)}.order-pick b{display:block;font-size:12px}.order-pick small{display:block;font-size:10px;color:var(--muted);line-height:1.3;margin-top:2px}.order-pick em{font-style:normal;color:var(--muted);font-size:10px}.order-qty{min-width:0;width:100%;border:1px solid var(--line);border-radius:7px;padding:7px;background:var(--paper)}
.margin-row{display:grid;grid-template-columns:minmax(0,1fr) auto 32px;gap:10px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}.margin-row:last-child{border-bottom:0}.margin-row b{display:block;font-size:13px}.margin-row small{display:block;color:var(--muted);font-size:10px;line-height:1.35;margin-top:2px}.margin-metric{text-align:right;display:grid;gap:4px;justify-items:end}.margin-metric strong{font-size:12px}.recipe-list{margin:18px 0 12px}.recipe-ingredient{display:grid;grid-template-columns:minmax(0,1fr) 210px;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line)}.recipe-ingredient:last-child{border-bottom:0}.recipe-ingredient b{display:block;font-size:13px}.recipe-ingredient small{display:block;font-size:10px;line-height:1.35;color:var(--muted);margin-top:2px}.recipe-inputs{display:grid;grid-template-columns:75px 62px 58px;gap:6px}.recipe-inputs input{min-width:0;border:1px solid var(--line);border-radius:8px;padding:8px;background:#fff;font-size:11px}.validate-recipe{display:flex;gap:9px;align-items:flex-start;font-size:12px;line-height:1.35;margin:14px 0;color:#4f4941}.validate-recipe input{margin-top:2px;accent-color:var(--gold)}
@media(max-width:819px){.order-foot{align-items:flex-start;flex-direction:column}.order-foot .actions{width:100%}.order-foot .btn{flex:1}.margin-row{grid-template-columns:minmax(0,1fr) 30px}.margin-metric{grid-column:1;text-align:left;justify-items:start;display:flex;gap:7px;align-items:center}.recipe-ingredient{grid-template-columns:1fr}.recipe-inputs{grid-template-columns:1fr 1fr 1fr}.order-pick{grid-template-columns:auto minmax(0,1fr) 62px 28px}}
/* V1.4 — Prévisions & Pilotage */
.forecast-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;padding:20px;border-radius:var(--radius);background:linear-gradient(135deg,#2a241b 0%,#151411 100%);color:#fff;box-shadow:0 16px 40px rgba(25,20,13,.18)}.forecast-hero .eyebrow{color:#e6bb72}.forecast-hero h2{font-size:28px;letter-spacing:-.05em;margin:5px 0}.forecast-hero p{max-width:660px;margin:0;color:#e5ddd0;font-size:13px;line-height:1.45}.forecast-hero-stat{min-width:180px;padding:13px 14px;border:1px solid rgba(255,255,255,.16);border-radius:13px;background:rgba(255,255,255,.07)}.forecast-hero-stat span,.forecast-hero-stat small{display:block;color:#d8cfc0;font-size:10px}.forecast-hero-stat b{display:block;margin:5px 0 3px;font-size:16px;color:#fff}
.forecast-service-card{overflow:hidden}.forecast-service-card h2{font-size:22px;letter-spacing:-.045em;margin:4px 0 0}.forecast-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:13px 0;border-bottom:1px solid var(--line)}.forecast-kpis div{min-width:0}.forecast-kpis small,.forecast-kpis span{display:block;font-size:10px;color:var(--muted);line-height:1.25}.forecast-kpis b{display:block;font-size:16px;margin:4px 0;letter-spacing:-.04em}.forecast-history{font-size:11px;color:var(--muted);padding:10px 0;border-bottom:1px solid var(--line);line-height:1.4}.prep-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:14px 0 8px}.prep-head h3{margin:3px 0 0;font-size:15px;letter-spacing:-.02em}.prep-list{display:grid}.prep-row{display:grid;grid-template-columns:38px minmax(0,1fr) auto;gap:10px;align-items:start;padding:10px 0;border-bottom:1px solid var(--line)}.prep-row:last-child{border-bottom:0}.prep-qty{width:34px;height:34px;border-radius:10px;background:var(--paper2);display:grid;place-items:center;font-weight:900;font-size:14px}.prep-row b{font-size:12px;display:block;line-height:1.3}.prep-row small,.prep-row em{font-size:10px;display:block;line-height:1.35;color:var(--muted);margin-top:2px}.prep-row em{font-style:normal;color:var(--orange)}.prep-empty{padding:12px 0;color:var(--muted);font-size:12px;line-height:1.45}.forecast-note{font-size:10px!important;color:var(--muted)!important;line-height:1.4!important;margin:10px 0 0!important}.target-details{margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}.target-details summary{font-size:12px;font-weight:800;color:var(--gold);cursor:pointer}.target-details[open] summary{margin-bottom:2px}.week-days{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:7px;margin-top:16px}.week-day{padding:10px 7px;border-radius:10px;background:var(--paper);border:1px solid transparent;min-width:0}.week-day.filled{background:#fff8eb;border-color:#f0d6a8}.week-day small,.week-day span{display:block;font-size:9px;color:var(--muted);text-transform:capitalize}.week-day b{display:block;font-size:12px;margin:5px 0 2px;letter-spacing:-.03em;white-space:nowrap}.weekly-foot{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;padding:12px;border-radius:12px;background:var(--paper)}.weekly-foot b,.weekly-foot span{display:block}.weekly-foot b{font-size:11px}.weekly-foot span{margin-top:3px;font-size:10px;line-height:1.35;color:var(--muted)}.weekly-alerts{display:grid;gap:7px;margin-top:13px}.weekly-alert{display:flex;align-items:flex-start;gap:8px;padding:9px 10px;border-radius:9px;background:var(--paper);font-size:11px;line-height:1.35;color:#5a534a}.weekly-alert i{display:block;flex:0 0 auto;width:7px;height:7px;border-radius:50%;margin-top:4px;background:#777}.weekly-alert.orange{background:var(--orange-soft);color:#875914}.weekly-alert.orange i{background:var(--orange)}.weekly-alert.vert{background:var(--sage-soft);color:#286046}.weekly-alert.vert i{background:var(--sage)}
@media(max-width:819px){.forecast-hero{align-items:flex-start;flex-direction:column}.forecast-hero-stat{width:100%}.week-days{grid-template-columns:repeat(4,minmax(0,1fr))}.forecast-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:450px){.forecast-hero{padding:16px}.forecast-hero h2{font-size:24px}.forecast-kpis{gap:6px}.forecast-kpis b{font-size:14px}.prep-row{grid-template-columns:34px minmax(0,1fr)}.prep-row .badge{grid-column:2;justify-self:start}.prep-qty{width:31px;height:31px}.weekly-foot{grid-template-columns:1fr}.week-days{grid-template-columns:repeat(4,minmax(0,1fr))}}

/* V1.5 — Salle & Expérience client */
.service-switch{display:flex;gap:8px;margin:0 0 14px}.service-switch button{border:1px solid var(--line);background:var(--white);padding:10px 14px;border-radius:999px;font-size:12px;font-weight:850}.service-switch button.active{background:var(--ink);border-color:var(--ink);color:#fff}.floor-stats{margin-bottom:0}.floor-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.9fr);gap:18px}.floor-zone{margin-top:20px}.floor-zone:first-child{margin-top:0}.floor-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.table-card{border:1px solid var(--line);border-radius:14px;padding:12px;min-height:132px;background:#fff;display:flex;flex-direction:column;gap:10px}.table-card.free{background:#fbfdfb;border-color:#d9eadd}.table-card.reserved{background:#fffaf0;border-color:#ecd7ad}.table-card.occupied{background:#edf7f0;border-color:#c9e3d1}.table-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.table-card-head span{display:block;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}.table-card-head h3{margin:3px 0 0;font-size:15px;letter-spacing:-.03em}.table-card-head>b{font-size:11px;color:var(--muted);background:var(--paper);padding:4px 6px;border-radius:7px}.table-guest b,.table-guest span{display:block}.table-guest b{font-size:12px}.table-guest span,.table-free,.table-more{font-size:10px;color:var(--muted);line-height:1.35}.table-status{margin-top:7px}.table-more{margin-top:auto;color:var(--gold);font-weight:750}.reservation-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}.reservation-row:last-child{border-bottom:0}.reservation-head{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.reservation-row b{font-size:13px}.reservation-row small{display:block;margin-top:3px;color:var(--muted);font-size:11px}.reservation-row p{margin:5px 0 0;font-size:11px;color:#4f4941;line-height:1.35}.reservation-actions{display:flex;gap:5px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.feedback-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}.feedback-row:last-child{border-bottom:0}.feedback-row p{font-size:12px;margin:5px 0;color:#4f4941;line-height:1.4}.reputation-kpis{display:flex;gap:8px;margin-bottom:4px}.reputation-kpis span{flex:1;padding:9px;border-radius:10px;background:var(--paper);font-size:10px;color:var(--muted);line-height:1.3}.reputation-kpis b{display:block;color:var(--ink);font-size:16px;margin-bottom:2px}.form-help{font-size:12px!important;color:var(--muted)!important;line-height:1.4!important;margin:0 0 12px!important}
@media(max-width:1020px){.floor-layout{grid-template-columns:1fr}.floor-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:819px){.floor-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.nav-inner{overflow-x:auto;justify-content:flex-start;scrollbar-width:none}.nav-inner::-webkit-scrollbar{display:none}.nav-btn{flex:0 0 62px}.floor-layout{gap:14px}}
@media(max-width:510px){.floor-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.table-card{min-height:120px}.reservation-row{flex-direction:column}.reservation-actions{justify-content:flex-start}.reputation-kpis{flex-direction:column}.feedback-row{flex-direction:column}}

/* V1.5.2 — Gestion des comptes */
.roster-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}.roster-actions small{margin:0!important}
@media(max-width:560px){.roster-actions{justify-content:flex-end}.roster-row>div:last-child{min-width:122px}}

/* V1.5.3 — suppression réservée au propriétaire */
.owner-account{color:#9a6b20!important;font-weight:800}.roster-actions .btn.danger{white-space:nowrap}


/* V1.6 — Guide pas à pas & mission du jour */
.help-icon{font-size:18px;font-weight:900;line-height:1;color:var(--gold);border:1px solid var(--line);background:var(--white)}
.help-icon:hover{border-color:var(--gold);background:#fff8eb}
.mission-card{display:flex;gap:14px;align-items:flex-start;margin:0 0 14px;padding:17px 18px;border:1px solid #ead4a8;border-radius:var(--radius);background:linear-gradient(135deg,#fffaf0 0%,#fffdf9 100%);box-shadow:0 8px 20px rgba(86,59,17,.06)}
.mission-icon{width:46px;height:46px;flex:0 0 46px;display:grid;place-items:center;border-radius:14px;background:var(--gold-soft);font-size:23px}
.mission-card h2{font-size:18px;letter-spacing:-.03em;margin:3px 0 6px}.mission-card p{margin:0;color:#615a51;font-size:13px;line-height:1.45;max-width:760px}.mission-steps{padding:0;margin:12px 0 0;display:flex;gap:8px;flex-wrap:wrap;list-style:none}.mission-steps li{display:flex;align-items:center;gap:6px;border-radius:999px;background:var(--white);border:1px solid var(--line);padding:6px 9px;font-size:11px;font-weight:720;color:#4d4740}.mission-steps span{display:grid;place-items:center;width:18px;height:18px;border-radius:50%;background:var(--ink);color:#fff;font-size:10px;font-weight:900}
.tutorial-focus{position:relative!important;z-index:1004!important;border-radius:16px!important;outline:4px solid rgba(191,135,52,.96)!important;outline-offset:5px!important;box-shadow:0 0 0 100vmax rgba(0,0,0,.42),0 0 0 7px rgba(255,255,255,.95),0 16px 45px rgba(0,0,0,.25)!important}
.guide-overlay{position:fixed;z-index:1003;inset:0;pointer-events:none}.guide-shade{position:absolute;inset:0;background:rgba(12,10,7,.06);pointer-events:auto}.guide-card{position:absolute;z-index:1005;pointer-events:auto;right:18px;bottom:18px;width:min(430px,calc(100vw - 36px));background:#fffdf9;border:1px solid #e3d3bb;border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.28);padding:18px}.guide-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.guide-icon{display:grid;place-items:center;width:36px;height:36px;border-radius:12px;background:var(--gold-soft);font-size:19px}.guide-icon.big{width:54px;height:54px;margin-bottom:12px;font-size:28px}.guide-counter{font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.08em}.guide-card h2{font-size:22px;letter-spacing:-.04em;margin:11px 0 6px}.guide-card p{margin:0;color:#5b544c;font-size:14px;line-height:1.48}.guide-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;margin-top:16px}.guide-link{border:0;background:transparent;color:#6e665d;text-decoration:underline;font-size:12px;font-weight:750;padding:8px 2px;margin-right:auto}.guide-dots{display:flex;gap:5px;margin-top:14px}.guide-dot{width:7px;height:7px;border-radius:20px;background:#ded3c2}.guide-dot.active{width:22px;background:var(--gold)}.welcome-card{left:50%;right:auto;top:50%;bottom:auto;transform:translate(-50%,-50%);width:min(460px,calc(100vw - 36px));padding:24px}.welcome-card h2{font-size:26px}.welcome-points{display:grid;gap:7px;margin:15px 0 0}.welcome-points span{font-size:12px;color:#504a43;background:var(--paper);padding:9px 10px;border-radius:10px}
@media(max-width:819px){.mission-card{padding:15px;gap:11px}.mission-icon{width:40px;height:40px;flex-basis:40px;font-size:20px}.mission-card h2{font-size:17px}.mission-steps{display:grid;grid-template-columns:1fr 1fr;gap:6px}.mission-steps li{font-size:10px;line-height:1.2}.guide-card{right:12px;bottom:12px;width:calc(100vw - 24px);padding:16px;border-radius:20px}.guide-card h2{font-size:20px}.guide-actions .btn{padding:10px 11px}.tutorial-focus{outline-width:3px!important;outline-offset:3px!important}}
@media(max-width:430px){.mission-steps{grid-template-columns:1fr}.guide-actions{flex-wrap:wrap}.guide-link{width:100%;text-align:left}.guide-actions .btn{flex:1}.welcome-card{padding:20px}}


/* =====================================================
   V1.7 — UX Terrain & Signaux visuels
   Objectif : comprendre en une seconde quoi faire,
   même sans être à l'aise avec une application.
   ===================================================== */
:root{
  --ink:#111827;
  --ink2:#1f2937;
  --paper:#f8fafc;
  --paper2:#eef2f7;
  --white:#ffffff;
  --gold:#f59e0b;
  --gold-soft:#fef3c7;
  --sage:#16a34a;
  --sage-soft:#dcfce7;
  --red:#dc2626;
  --red-soft:#fee2e2;
  --orange:#ea580c;
  --orange-soft:#ffedd5;
  --muted:#64748b;
  --line:#dbe3ee;
  --shadow:0 18px 48px rgba(15,23,42,.10);
}
html,body{background:linear-gradient(180deg,#f8fafc 0%,#eef4fa 100%)}
body{color:var(--ink)}
.app{padding-bottom:96px}
.topbar{background:rgba(255,255,255,.92);border-bottom:1px solid #dbe3ee;box-shadow:0 1px 0 rgba(15,23,42,.04)}
.brand-mark{background:linear-gradient(135deg,#111827 0%,#334155 100%);color:#fbbf24;box-shadow:0 8px 18px rgba(15,23,42,.22)}
.brand b{font-size:15px}.brand small{font-weight:650;color:#64748b}
.date-picker{border-color:#cbd5e1;background:#fff;font-weight:750;min-height:40px}
.top-icon,.avatar{min-width:40px;min-height:40px;border-radius:13px}
.avatar{background:#111827;box-shadow:0 6px 14px rgba(15,23,42,.18)}
.help-icon{color:#b45309;border-color:#fde68a;background:#fffbeb}
.main{max-width:1360px;padding:26px 22px 40px}
.eyebrow{color:#b45309;font-weight:900;letter-spacing:.13em}
.page-title{font-size:31px;line-height:1.02}.page-intro{font-size:15px;max-width:760px;color:#64748b}
.card{border-color:#dbe3ee;box-shadow:0 8px 22px rgba(15,23,42,.055)}
.card-pad,.form-card{padding:20px}
.hero{background:linear-gradient(135deg,#111827 0%,#1e293b 60%,#312e81 100%);box-shadow:0 18px 46px rgba(15,23,42,.22)}
.hero:after{border-color:rgba(251,191,36,.38)}
.hero .eyebrow{color:#fde68a}.hero p{color:#e2e8f0}
.hero.hero-rouge{background:linear-gradient(135deg,#7f1d1d 0%,#b91c1c 62%,#ea580c 100%)}
.hero.hero-orange{background:linear-gradient(135deg,#7c2d12 0%,#c2410c 58%,#f59e0b 135%)}
.hero.hero-vert{background:linear-gradient(135deg,#14532d 0%,#15803d 60%,#16a34a 120%)}
.hero.hero-rouge .eyebrow,.hero.hero-orange .eyebrow,.hero.hero-vert .eyebrow{color:#fef3c7}
.badge{font-weight:900;letter-spacing:.005em;padding:6px 10px;border:1px solid transparent;box-shadow:0 1px 0 rgba(15,23,42,.05)}
.badge.vert{background:var(--sage-soft);color:#166534;border-color:#86efac}
.badge.orange{background:var(--orange-soft);color:#c2410c;border-color:#fdba74}
.badge.rouge{background:var(--red-soft);color:#b91c1c;border-color:#fca5a5}
.badge.neutral{background:#e2e8f0;color:#475569;border-color:#cbd5e1}
.service-card{border-width:1px;border-left-width:6px;transition:transform .18s ease,box-shadow .18s ease}
.service-card:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(15,23,42,.10)}
.service-card.service-rouge{border-left-color:var(--red);background:linear-gradient(135deg,#fff 0%,#fff5f5 100%)}
.service-card.service-orange{border-left-color:var(--orange);background:linear-gradient(135deg,#fff 0%,#fff7ed 100%)}
.service-card.service-vert{border-left-color:var(--sage);background:linear-gradient(135deg,#fff 0%,#f0fdf4 100%)}
.service-name{font-size:17px}.service-meta{font-size:13px}.service-meta b{font-size:20px}.team-chip{background:#eff6ff;color:#334155;border:1px solid #dbeafe;font-weight:750}
.progress{height:9px;background:#e2e8f0}.progress>span{background:linear-gradient(90deg,#22c55e,#16a34a)}
.priority{border:1px solid #dbe3ee;border-radius:14px;padding:12px 13px;background:rgba(255,255,255,.96);transition:transform .15s ease}.priority:hover{transform:translateX(2px)}
.priority-rouge{border-color:#fecaca;background:#fff7f7}.priority-orange{border-color:#fed7aa;background:#fffaf3}.priority-vert{border-color:#bbf7d0;background:#f4fff6}
.priority-mark{width:11px;height:11px;margin-top:4px;box-shadow:0 0 0 4px rgba(148,163,184,.12)}
.priority-mark.rouge{background:var(--red);box-shadow:0 0 0 4px #fee2e2}.priority-mark.orange{background:var(--orange);box-shadow:0 0 0 4px #ffedd5}.priority-mark.vert{background:var(--sage);box-shadow:0 0 0 4px #dcfce7}
.priority b{font-size:14px}.priority span{font-size:12px;color:#475569}
.alert-row{border:1px solid #e2e8f0;border-radius:13px;padding:11px 12px;background:#fff}.alert-row.alert-rouge{background:#fff6f6;border-color:#fecaca}.alert-row.alert-orange{background:#fffaf3;border-color:#fed7aa}.alert-row b{font-size:14px}.alert-row p{color:#475569}
.quick{border-color:#dbe3ee;border-radius:14px;min-height:82px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);transition:all .18s ease}.quick:hover{border-color:#f59e0b;box-shadow:0 10px 20px rgba(245,158,11,.14);transform:translateY(-2px)}.quick span{font-size:22px}.quick b{font-size:12px}
.nav{background:rgba(15,23,42,.97);box-shadow:0 -10px 28px rgba(15,23,42,.18);padding-top:8px}.nav-btn{border-radius:12px;color:#cbd5e1;min-height:48px}.nav-btn.active{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#f97316 100%);box-shadow:0 5px 12px rgba(249,115,22,.30)}
.btn{border-radius:12px;min-height:42px;padding:10px 14px;font-size:13px;box-shadow:0 4px 10px rgba(15,23,42,.08);transition:transform .15s ease,box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(15,23,42,.13)}.btn:active{transform:translateY(0)}
.btn.gold{background:linear-gradient(135deg,#f59e0b 0%,#f97316 100%);color:#1f2937}.btn.light{background:#eaf0f7;color:#1e293b}.btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}
.field input,.field select,.field textarea{min-height:44px;border-color:#cbd5e1;background:#fff;font-size:14px}.field input:focus,.field select:focus,.field textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 4px rgba(245,158,11,.20)}
.check-row{position:relative;border:1px solid #e2e8f0;border-radius:14px;padding:12px;margin-bottom:8px;background:#fff;box-shadow:0 2px 6px rgba(15,23,42,.025);transition:border .15s ease,transform .15s ease}.check-row:hover{border-color:#fbbf24;transform:translateX(2px)}.check-row:last-child{border-bottom:1px solid #e2e8f0}.check-toggle{width:26px;height:26px;border-radius:9px;border-color:#94a3b8}.check-toggle:checked{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#16a34a;box-shadow:0 0 0 4px #dcfce7}.check-label{font-size:14px;font-weight:750}.check-done{background:#f0fdf4;border-color:#86efac}.check-done .check-label{text-decoration:none;color:#166534}.check-done:after{content:"C’est fait";font-size:10px;font-weight:900;color:#166534;background:#dcfce7;border:1px solid #86efac;border-radius:999px;padding:4px 7px;margin-left:auto}
.stock-row{border:1px solid #e2e8f0;border-radius:14px;padding:12px;margin-bottom:8px;background:#fff}.stock-row:last-child{border-bottom:1px solid #e2e8f0}.stock-row.critical{background:#fff6f6;border-color:#fecaca}.stock-row.critical .stock-qty{color:#dc2626}.icon-btn{width:35px;height:35px;border-radius:10px;border-color:#cbd5e1;transition:all .15s ease}.icon-btn:hover{border-color:#f59e0b;background:#fffbeb;transform:scale(1.04)}
.report-stat{border-color:#dbe3ee;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);padding:14px}.report-stat strong{font-size:22px}.table-card{border-width:2px;box-shadow:0 4px 12px rgba(15,23,42,.05);transition:transform .18s ease}.table-card:hover{transform:translateY(-2px)}.table-card.free{background:#f0fdf4;border-color:#86efac}.table-card.reserved{background:#fff7ed;border-color:#fdba74}.table-card.occupied{background:#eff6ff;border-color:#93c5fd}.table-card-head>b{background:#fff;color:#475569;border:1px solid #dbe3ee}
.status-guide{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0 0 14px}.status-guide-item{display:flex;align-items:center;gap:9px;padding:11px;border-radius:15px;border:1px solid #dbe3ee;background:#fff}.status-guide-item>span{display:grid;place-items:center;width:30px;height:30px;border-radius:10px;color:#fff;font-weight:950;font-size:16px}.status-guide-item b,.status-guide-item small{display:block}.status-guide-item b{font-size:12px}.status-guide-item small{font-size:10px;color:#475569;line-height:1.25;margin-top:2px}.status-guide-item.urgent{background:#fff4f4;border-color:#fecaca}.status-guide-item.urgent>span{background:#dc2626}.status-guide-item.todo{background:#fff7ed;border-color:#fed7aa}.status-guide-item.todo>span{background:#ea580c}.status-guide-item.done{background:#f0fdf4;border-color:#bbf7d0}.status-guide-item.done>span{background:#16a34a}
.mission-card{border-color:#fde68a;background:linear-gradient(135deg,#fffbeb 0%,#fff 100%);box-shadow:0 9px 22px rgba(245,158,11,.11)}.mission-icon{background:linear-gradient(135deg,#fef3c7,#fed7aa);box-shadow:0 6px 12px rgba(234,88,12,.13)}.mission-steps li{border-color:#dbe3ee;background:#fff;font-weight:800}.mission-steps span{background:linear-gradient(135deg,#f59e0b,#f97316)}
.role-cuisine .mission-card{background:linear-gradient(135deg,#f5f3ff 0%,#fff 100%);border-color:#ddd6fe}.role-cuisine .mission-icon{background:linear-gradient(135deg,#ddd6fe,#c4b5fd)}.role-cuisine .mission-steps span{background:linear-gradient(135deg,#7c3aed,#6d28d9)}
.role-salle .mission-card{background:linear-gradient(135deg,#fff1f2 0%,#fff 100%);border-color:#fecdd3}.role-salle .mission-icon{background:linear-gradient(135deg,#fecdd3,#fda4af)}.role-salle .mission-steps span{background:linear-gradient(135deg,#e11d48,#be123c)}
.role-bar .mission-card{background:linear-gradient(135deg,#ecfeff 0%,#fff 100%);border-color:#a5f3fc}.role-bar .mission-icon{background:linear-gradient(135deg,#a5f3fc,#67e8f9)}.role-bar .mission-steps span{background:linear-gradient(135deg,#0891b2,#0e7490)}
.toast{background:#111827;border:1px solid #334155;box-shadow:0 16px 38px rgba(15,23,42,.3)}
.tutorial-focus{outline-color:rgba(245,158,11,.98)!important}.guide-card{border-color:#fde68a;box-shadow:0 26px 72px rgba(15,23,42,.30)}.guide-icon{background:linear-gradient(135deg,#fef3c7,#fed7aa)}.guide-dot.active{background:#f97316}
@media(min-width:1020px){
  .app{padding-bottom:0;padding-left:216px}.topbar-inner{max-width:none;padding:14px 28px}.main{max-width:1440px;padding:28px 30px 44px}.nav{position:fixed;left:0;right:auto;top:0;bottom:0;width:216px;padding:102px 12px 20px;background:linear-gradient(180deg,#111827 0%,#0f172a 100%);box-shadow:10px 0 28px rgba(15,23,42,.14);justify-content:flex-start}.nav-inner{width:100%;display:grid;gap:6px;align-content:start;overflow:visible}.nav-btn{width:100%;grid-template-columns:30px 1fr;justify-items:start;gap:9px;padding:11px 12px;font-size:13px;text-align:left;min-height:48px}.nav-btn .nav-icon{font-size:18px}.nav-btn.active{box-shadow:none}.dashboard-heading{margin-bottom:22px}
}
@media(max-width:819px){
  .main{padding:18px 14px 108px}.topbar-inner{padding:10px 14px}.brand small{max-width:145px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-picker{max-width:122px;min-height:38px;font-size:12px}.top-controls{gap:5px}.top-icon,.avatar{min-width:38px;min-height:38px}.page-title{font-size:28px}.dashboard-heading{align-items:flex-start;flex-direction:column}.dashboard-heading .actions{width:100%}.dashboard-heading .actions .btn{flex:1}.status-guide{grid-template-columns:1fr;gap:7px}.status-guide-item{padding:9px 10px}.status-guide-item small{font-size:11px}.grid-2,.grid-3,.grid-main,.report-grid{grid-template-columns:1fr}.service-card{padding:17px}.service-meta{gap:20px}.hero h2{font-size:21px}.card-pad,.form-card{padding:16px}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.quick{min-height:76px}.stock-row{grid-template-columns:minmax(0,1fr) auto}.stock-actions{grid-column:1/-1;justify-content:flex-end}.check-row{padding:13px}.mission-card{border-radius:18px}
}
@media(max-width:460px){
  .brand b{font-size:14px}.top-controls .help-icon{display:none}.date-picker{max-width:115px}.page-intro{font-size:14px}.btn{min-height:44px}.actions .btn{padding:10px 10px}.service-meta b{font-size:19px}.nav-btn{min-width:64px}.nav-inner{gap:3px}.nav-btn.active{border-radius:12px}.quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-stat strong{font-size:20px}
}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition:none!important;scroll-behavior:auto!important}}


/* =====================================================
   V1.8 — Sens, adhésion équipe et aide contextualisée
   L'app explique son utilité sans être intrusive.
   ===================================================== */
.purpose-card{display:flex;gap:14px;align-items:flex-start;margin:0 0 14px;padding:18px;border:1px solid #a7f3d0;border-radius:18px;background:linear-gradient(135deg,#ecfdf5 0%,#ffffff 58%,#eff6ff 100%);box-shadow:0 10px 24px rgba(16,185,129,.10)}
.purpose-icon{width:48px;height:48px;flex:0 0 48px;display:grid;place-items:center;border-radius:15px;background:linear-gradient(135deg,#bbf7d0,#99f6e4);font-size:24px;box-shadow:0 7px 15px rgba(16,185,129,.14)}
.purpose-copy{min-width:0}.purpose-card h2{margin:3px 0 6px;font-size:18px;letter-spacing:-.025em;color:#064e3b}.purpose-card p{margin:0;max-width:850px;line-height:1.48}.purpose-common{font-weight:750;color:#14532d;font-size:13px}.purpose-detail{margin-top:6px!important;font-size:12.5px;color:#334155}.purpose-link{display:inline-flex;gap:8px;align-items:center;margin:11px 0 0;padding:0;border:0;background:transparent;color:#0f766e;font-size:12px;font-weight:900;text-decoration:underline;text-underline-offset:3px;cursor:pointer}.purpose-link span{font-size:17px;line-height:0}.purpose-link:hover{color:#047857}
.purpose-overlay{position:fixed;z-index:1100;inset:0}.purpose-shade{position:absolute;inset:0;background:rgba(15,23,42,.56);backdrop-filter:blur(3px)}
.purpose-modal{position:absolute;z-index:1101;left:50%;top:50%;transform:translate(-50%,-50%);width:min(540px,calc(100vw - 32px));max-height:calc(100dvh - 32px);overflow:auto;border:1px solid #a7f3d0;border-radius:24px;background:#fff;padding:25px;box-shadow:0 30px 90px rgba(15,23,42,.35)}
.purpose-close{position:absolute;right:14px;top:12px;width:34px;height:34px;border:1px solid #cbd5e1;border-radius:11px;background:#fff;color:#334155;font-size:23px;line-height:1;cursor:pointer}.purpose-close:hover{background:#f8fafc;border-color:#94a3b8}.purpose-modal-icon{width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:linear-gradient(135deg,#bbf7d0,#99f6e4);font-size:30px;margin-bottom:13px}.purpose-modal h2{margin:5px 35px 8px 0;font-size:25px;letter-spacing:-.04em;color:#064e3b}.purpose-modal p{margin:0;line-height:1.5}.purpose-modal-common{font-weight:800;color:#14532d;font-size:14px}.purpose-modal-detail{margin-top:10px!important;color:#334155;font-size:13px}.purpose-rules{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin:17px 0}.purpose-rules>div{border:1px solid #dbeafe;border-radius:14px;background:#f8fafc;padding:11px 9px}.purpose-rules span{display:grid;place-items:center;width:24px;height:24px;border-radius:8px;background:#0f766e;color:#fff;font-size:12px;font-weight:900;margin-bottom:7px}.purpose-rules b,.purpose-rules small{display:block}.purpose-rules b{font-size:12px;color:#0f172a}.purpose-rules small{font-size:10px;line-height:1.3;color:#475569;margin-top:3px}
.welcome-common{font-weight:800;color:#14532d!important}.welcome-role{margin-top:9px!important;color:#334155!important}.welcome-role b{color:#0f766e}
.role-cuisine .purpose-card{background:linear-gradient(135deg,#f5f3ff 0%,#ffffff 62%,#f0fdf4 100%);border-color:#ddd6fe}.role-cuisine .purpose-icon{background:linear-gradient(135deg,#ddd6fe,#c4b5fd)}.role-cuisine .purpose-card h2{color:#5b21b6}.role-cuisine .purpose-common{color:#5b21b6}.role-cuisine .purpose-link{color:#6d28d9}
.role-salle .purpose-card{background:linear-gradient(135deg,#fff1f2 0%,#ffffff 62%,#fefce8 100%);border-color:#fecdd3}.role-salle .purpose-icon{background:linear-gradient(135deg,#fecdd3,#fda4af)}.role-salle .purpose-card h2{color:#9f1239}.role-salle .purpose-common{color:#9f1239}.role-salle .purpose-link{color:#be123c}
.role-bar .purpose-card{background:linear-gradient(135deg,#ecfeff 0%,#ffffff 62%,#eff6ff 100%);border-color:#a5f3fc}.role-bar .purpose-icon{background:linear-gradient(135deg,#a5f3fc,#67e8f9)}.role-bar .purpose-card h2{color:#155e75}.role-bar .purpose-common{color:#155e75}.role-bar .purpose-link{color:#0e7490}
@media(max-width:819px){.purpose-card{padding:15px;gap:11px;border-radius:17px}.purpose-icon{width:40px;height:40px;flex-basis:40px;border-radius:13px;font-size:21px}.purpose-card h2{font-size:17px}.purpose-common{font-size:12.5px}.purpose-detail{font-size:12px}.purpose-modal{padding:21px 18px;border-radius:21px}.purpose-modal h2{font-size:23px}.purpose-rules{grid-template-columns:1fr;gap:7px}.purpose-rules>div{display:grid;grid-template-columns:25px 1fr;column-gap:8px;align-items:start}.purpose-rules span{grid-row:1 / span 2;margin:0}.purpose-rules b{padding-top:1px}.purpose-rules small{grid-column:2;margin-top:2px}}
