/* === LNPC — Design partagé (Material). Tout se règle ICI, une seule fois. === */
:root{
  --primary:#0B57D0; --on-primary:#fff;
  --primary-container:#D3E3FD; --on-primary-container:#041E49;
  --surface:#FFFFFF; --surface-2:#ECF1FA; --bg:#F6F8FC;
  --on-surface:#1A1C1E; --on-surface-variant:#44474E; --outline:#DCE2EB;
  --error:#D32F2F; --error-container:#FCE4E2;
  --warn:#B26A00; --warn-container:#FDEEDA;
  --ok:#1E8E3E; --ok-container:#E3F6E8;
  --tertiary:#7A4FE6; --tertiary-container:#ECE3FE; --on-tertiary-container:#2A0A66;
  /* Fonds colorés des tuiles (couleurs logiques façon Google) */
  --tint-blue:#E8F0FE; --tint-red:#FCE8E6; --tint-amber:#FEF3E0; --tint-green:#E6F4EA;
  --tint-grey:#F1F3F4; --tint-purple:#F1EBFE;
  --radius-l:24px; --radius-m:16px; --shadow:0 1px 3px rgba(0,0,0,.08);
}
html.dark{
  --primary:#A8C7FA; --on-primary:#06305F;
  --primary-container:#284878; --on-primary-container:#D7E3FF;
  --surface:#1E2125; --surface-2:#2A2F36; --bg:#121417;
  --on-surface:#E3E2E6; --on-surface-variant:#C2C6CF; --outline:#2D323A;
  --error:#F2B8B5; --error-container:#3B1A17;
  --warn:#F4C26B; --warn-container:#3A2A05;
  --ok:#8FD89A; --ok-container:#16331C; --shadow:0 1px 3px rgba(0,0,0,.4);
  --tertiary:#CFBCFF; --tertiary-container:#372A5E; --on-tertiary-container:#E9DDFF;
  --tint-blue:#1A2738; --tint-red:#33211F; --tint-amber:#322713; --tint-green:#16301E;
  --tint-grey:#23272C; --tint-purple:#241B3A;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
/* Barres de defilement fines et discretes (au lieu de l'ascenseur natif). */
*{scrollbar-width:thin;scrollbar-color:var(--outline) transparent;}
*::-webkit-scrollbar{width:7px;height:7px;}
*::-webkit-scrollbar-track{background:transparent;}
*::-webkit-scrollbar-thumb{background:var(--outline);border-radius:8px;}
*::-webkit-scrollbar-thumb:hover{background:var(--on-surface-variant);}
*::-webkit-scrollbar-corner{background:transparent;}
body{margin:0;font-family:'Roboto',sans-serif;background:var(--bg);color:var(--on-surface);
  -webkit-font-smoothing:antialiased;transition:background .25s,color .25s;}
.material-symbols-outlined{line-height:1;}
.app{max-width:480px;margin:0 auto;min-height:100vh;padding:0 16px 112px;position:relative;}

/* App bar / top bar */
.appbar{display:flex;align-items:center;justify-content:space-between;padding:18px 4px 8px;}
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:6px;background:var(--bg);padding:12px 0 8px;}
.topbar .title{flex:1;font-size:20px;font-weight:500;}
.brand{display:flex;align-items:center;gap:10px;}
.logo{width:38px;height:38px;border-radius:11px;background:var(--primary);color:var(--on-primary);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;}
.brand-logo{height:36px;width:auto;max-width:130px;display:block;object-fit:contain;}
.brand small{display:block;color:var(--on-surface-variant);font-size:12px;}
.brand strong{font-size:18px;font-weight:500;}
.appbar .right{display:flex;align-items:center;gap:6px;}
.icon-btn{width:42px;height:42px;border:0;background:transparent;color:var(--on-surface);border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;}
.icon-btn:active{background:var(--surface-2);}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--primary-container);
  color:var(--on-primary-container);display:flex;align-items:center;justify-content:center;font-weight:500;font-size:14px;}

/* Search */
.search{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--outline);
  border-radius:28px;padding:13px 18px;margin:10px 0 8px;box-shadow:var(--shadow);}
.search input{border:0;outline:0;background:transparent;font:inherit;font-size:15px;flex:1;color:var(--on-surface);}
.search input::placeholder{color:var(--on-surface-variant);}
.search .material-symbols-outlined{color:var(--primary);font-size:22px;}

.section-title{font-size:13px;font-weight:500;letter-spacing:.4px;text-transform:uppercase;
  color:var(--on-surface-variant);margin:22px 4px 12px;}

/* Ajout rapide (barre input + bouton) — ex. tâche rapide. */
.quick-add{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--outline);border-radius:24px;padding:7px 8px 7px 16px;box-shadow:var(--shadow);}
.quick-add > .material-symbols-outlined{color:var(--primary);font-size:22px;flex:0 0 auto;}
.quick-add input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:15px;color:var(--on-surface);min-width:0;}
.quick-add button{flex:0 0 auto;width:38px;height:38px;border:0;border-radius:50%;background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;}
.quick-add button .material-symbols-outlined{font-size:20px;}

/* Ma journée */
.day{display:flex;flex-direction:column;gap:10px;}
.day-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--outline);
  border-radius:var(--radius-m);padding:12px 14px;}
.day-row .time{font-size:13px;font-weight:500;color:var(--on-surface-variant);width:42px;}
.dot{width:10px;height:10px;border-radius:50%;background:var(--ok);flex:0 0 auto;}
.dot.up{background:var(--outline);}
.d-main{flex:1;}
.d-main strong{font-size:15px;font-weight:500;display:block;}
.d-main span{font-size:13px;color:var(--on-surface-variant);}
.day-row .chk{color:var(--ok);font-size:22px;}

/* "A traiter" : accordeon de cartes qui s'ouvrent en tiroir sur place. */
.acc-list{display:flex;flex-direction:column;gap:10px;}
.acc{background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-m);overflow:hidden;}
.acc-head,.acc-link{display:flex;align-items:center;gap:14px;padding:13px 14px;cursor:pointer;user-select:none;text-decoration:none;color:inherit;}
.acc-head:active,.acc-link:active{background:var(--surface-2);}
.acc-ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.acc-ic .material-symbols-outlined{font-size:22px;}
.acc-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.acc-lbl{font-size:15px;font-weight:500;}
.acc-preview{font-size:12px;color:var(--on-surface-variant);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.acc-preview:empty{display:none;}
.acc:not(.collapsed) .acc-preview{display:none;}
.acc-count{min-width:26px;height:24px;padding:0 8px;border-radius:14px;background:var(--primary-container);color:var(--on-primary-container);
  font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.acc-count.zero{background:var(--surface-2);color:var(--on-surface-variant);font-weight:500;}
.acc-chev{color:var(--on-surface-variant);transition:transform .28s cubic-bezier(.4,0,.2,1);flex:0 0 auto;}
.acc.collapsed .acc-chev{transform:rotate(-90deg);}
.acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1);}
.acc:not(.collapsed) .acc-body{grid-template-rows:1fr;}
.acc-body > .acc-inner{overflow:hidden;min-height:0;}
.acc:not(.collapsed) > .acc-body > .acc-inner{overflow-y:auto;max-height:360px;}
.acc-inner{padding:0 10px;}
.acc:not(.collapsed) .acc-inner{padding:0 10px 10px;}
/* Lignes a l'interieur d'un tiroir. */
.lp-item{display:flex;align-items:center;gap:12px;border-radius:12px;padding:11px 12px;cursor:pointer;}
.lp-item + .lp-item{border-top:1px solid var(--outline);}
.lp-item:active{background:var(--surface-2);}
.lp-item .main{flex:1;min-width:0;}
.lp-item .main strong{display:block;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lp-item .main span{font-size:12px;color:var(--on-surface-variant);}
.lp-more{text-decoration:none;}
.lp-more .main span{color:var(--primary);font-weight:500;}
.lp-more .go{color:var(--primary);}

/* Widget "Mes taches" de l'accueil : liste scrollable, tap pour cocher. */
.mt-list{max-height:320px;overflow-y:auto;-webkit-overflow-scrolling:touch;
  background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-m);padding:2px 4px;}
.mt-item{display:flex;align-items:center;gap:12px;padding:11px 8px;transition:opacity .3s;}
.mt-item + .mt-item{border-top:1px solid var(--outline);}
.mt-item:active{background:var(--surface-2);}
.mt-item.removing{opacity:0;}
.mt-item.done .mt-t{text-decoration:line-through;color:var(--on-surface-variant);}
.mt-check{flex:0 0 auto;border:0;background:transparent;color:var(--primary);cursor:pointer;display:flex;align-items:center;padding:0;}
.mt-check .material-symbols-outlined{font-size:24px;}
.mt-item.done .mt-check{color:var(--ok);}
.mt-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.mt-t{font-size:14px;font-weight:500;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mt-d{font-size:12px;color:var(--on-surface-variant);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mt-item.late .mt-d{color:var(--error);font-weight:500;}
.mt-all{margin-top:8px;}
/* Sections repliables du widget (En retard / Bientôt). */
.mt-sec{display:flex;align-items:center;justify-content:space-between;width:100%;border:0;background:transparent;cursor:pointer;
  padding:14px 6px 6px;font:inherit;color:var(--on-surface);}
.mt-sec-l{font-size:14px;font-weight:600;}
.mt-sec-l.late{color:var(--error);}
.mt-sec-ar{color:var(--on-surface-variant);transition:transform .2s;}
.mt-sec.open .mt-sec-ar{transform:rotate(180deg);}
.mt-sec-body{margin-top:2px;}

/* Brief du jour (redige) : bandeau resume en tete de "Ma journee". */
.day-brief{background:var(--surface-2);color:var(--on-surface);border:1px solid var(--outline);border-radius:var(--radius-m);
  padding:12px 14px;margin:0 0 12px;font-size:14px;line-height:1.5;}

/* Carte "en cours" / chantier */
.now-card,.job{background:var(--primary-container);color:var(--on-primary-container);border-radius:var(--radius-l);
  padding:16px;box-shadow:var(--shadow);}
.now-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.now-head .time-now{font-weight:700;font-size:15px;}
.badge-now,.job .badge{display:inline-block;font-size:12px;font-weight:500;background:rgba(127,127,127,.18);
  padding:3px 10px;border-radius:20px;}
.now-card h3{margin:0;font-size:18px;font-weight:500;}
.now-card>p{margin:3px 0 13px;font-size:14px;opacity:.85;}
.job h2{margin:0;font-size:20px;font-weight:500;}
.job .meta{margin:6px 0 0;font-size:14px;opacity:.85;display:flex;align-items:center;gap:7px;}
.now-actions,.job-actions{display:flex;gap:9px;flex-wrap:wrap;}
.job-actions{margin-top:14px;}
.now-actions{margin-bottom:11px;}
.pill{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;background:var(--surface);
  color:var(--primary);border-radius:16px;padding:10px;font-size:13px;font-weight:500;cursor:pointer;transition:transform .12s;}
.pill:active{transform:scale(.96);}
.pill .material-symbols-outlined{font-size:19px;}
.closing{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  background:var(--primary);color:var(--on-primary);border-radius:16px;padding:12px;font:inherit;font-size:14px;font-weight:500;transition:transform .12s;}
.closing:active{transform:scale(.98);}

/* Tuiles "à traiter" */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.tile{background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-m);
  padding:15px;cursor:pointer;transition:transform .12s,box-shadow .12s;}
.tile:active{transform:scale(.97);}
.tile:hover{box-shadow:0 2px 10px rgba(0,0,0,.1);}
.tile .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;}
.ic .material-symbols-outlined{font-size:22px;}
.count{font-size:22px;font-weight:700;}
.tile .lbl{font-size:14px;color:var(--on-surface-variant);}
/* Icônes de tuiles : pleines et vives (look Google). */
.b-blue{background:var(--primary);color:#fff;}
.b-red{background:var(--error);color:#fff;}
.b-warn{background:var(--warn);color:#fff;}
.b-ok{background:var(--ok);color:#fff;}
.b-grey{background:var(--tertiary);color:#fff;}
.count.red{color:var(--error);} .count.warn{color:var(--warn);}
/* Fond coloré de toute la tuile selon son icône (couleurs logiques). */
.tile:has(.b-blue){background:var(--tint-blue);border-color:transparent;}
.tile:has(.b-red){background:var(--tint-red);border-color:transparent;}
.tile:has(.b-warn){background:var(--tint-amber);border-color:transparent;}
.tile:has(.b-ok){background:var(--tint-green);border-color:transparent;}
.tile:has(.b-grey){background:var(--tint-purple);border-color:transparent;}
.tile:has(.b-blue) .count{color:var(--primary);}
.tile:has(.b-red) .count{color:var(--error);}
.tile:has(.b-warn) .count{color:var(--warn);}
.tile:has(.b-ok) .count{color:var(--ok);}
.tile:has(.b-grey) .count{color:var(--tertiary);}
.tile .lbl{font-weight:500;color:var(--on-surface);}

/* Chips */
.chips{display:flex;gap:10px;overflow-x:auto;padding:2px 4px 4px;scrollbar-width:none;}
.chips::-webkit-scrollbar{display:none;}
.chip{flex:0 0 auto;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--outline);
  border-radius:20px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--on-surface);cursor:pointer;white-space:nowrap;transition:transform .12s;}
.chip:active{transform:scale(.96);}
.chip.accent{background:var(--primary);color:var(--on-primary);border-color:var(--primary);}
.chip .material-symbols-outlined{font-size:19px;color:var(--primary);}
.chip.accent .material-symbols-outlined{color:var(--on-primary);}

/* Avancement (stepper) */
.stepper{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 4px;scrollbar-width:none;}
.stepper::-webkit-scrollbar{display:none;}
.step{flex:0 0 auto;display:flex;align-items:center;gap:6px;border-radius:20px;padding:7px 13px;font-size:13px;
  font-weight:500;border:1px solid var(--outline);color:var(--on-surface-variant);background:var(--surface);}
.step.done{background:var(--ok-container);color:var(--ok);border-color:transparent;}
.step.current{border-color:var(--primary);color:var(--primary);}
.step .material-symbols-outlined{font-size:17px;}

/* Lignes d'action (clôture) */
.rows{display:flex;flex-direction:column;gap:10px;}
.row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--outline);
  border-radius:var(--radius-m);padding:14px;cursor:pointer;transition:transform .12s,box-shadow .12s;}
.row:active{transform:scale(.98);}
.row:hover{box-shadow:0 2px 10px rgba(0,0,0,.08);}
.st{width:40px;height:40px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;}
.st .material-symbols-outlined{font-size:22px;}
.st.todo{background:var(--surface-2);color:var(--on-surface-variant);}
.st.done{background:var(--ok-container);color:var(--ok);}
.st.key{background:var(--primary-container);color:var(--primary);}
.row .main{flex:1;}
.row .main strong{display:block;font-size:15px;font-weight:500;}
.row .main span{font-size:13px;color:var(--on-surface-variant);}
.row .go{color:var(--on-surface-variant);}
/* Lignes et pilules utilisees comme liens <a> : pas de soulignement ni couleur de lien. */
a.row{text-decoration:none;color:inherit;}
a.pill{text-decoration:none;}
a.chip{text-decoration:none;}
a.tile{text-decoration:none;color:inherit;}
a.icon-btn{text-decoration:none;color:var(--on-surface-variant);}
.pill.disabled{opacity:.45;pointer-events:none;cursor:default;}
.seg-card{background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-m);padding:14px;}
.seg-card>p{margin:0 0 12px;font-size:15px;font-weight:500;}
.seg-card input,.seg-card select,.seg-card textarea{width:100%;border:1px solid var(--outline);border-radius:12px;padding:11px 14px;
  font:inherit;font-size:14px;background:var(--bg);color:var(--on-surface);margin-bottom:10px;}
.seg-card textarea{resize:vertical;}
.pv-lbl{display:block;font-size:12px;color:var(--on-surface-variant);margin:2px 0 4px;}
.pv-check{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;}
.pv-sig{width:100%;height:160px;border:1px dashed var(--outline);border-radius:12px;background:#fff;touch-action:none;display:block;}
.seg-btn-full{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--outline);
  background:var(--surface);color:var(--on-surface);border-radius:12px;padding:10px;font:inherit;font-size:14px;font-weight:500;cursor:pointer;margin-top:8px;}
.pv-note{font-size:12px;color:var(--on-surface-variant);margin:8px 0 0;}
.pv-status{text-align:center;font-size:14px;margin:14px 0 0;min-height:20px;}
.notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;
  background:var(--error);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;}
/* Toasts (notifications discretes) */
.toast-wrap{position:fixed;left:50%;bottom:92px;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;}
.toast{background:var(--on-surface);color:var(--bg);padding:11px 18px;border-radius:22px;font-size:14px;font-weight:500;
  box-shadow:0 3px 14px rgba(0,0,0,.28);max-width:90vw;text-align:center;opacity:0;transform:translateY(12px);transition:opacity .2s,transform .2s;}
.toast.show{opacity:1;transform:none;}
.toast.err{background:var(--error);color:#fff;}
.toast.ok{background:var(--ok);color:#fff;}
/* Bouton micro (dictee vocale) */
.mic-btn{border:0;background:var(--surface-2);color:var(--primary);border-radius:50%;width:30px;height:30px;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;vertical-align:middle;margin-left:6px;}
.mic-btn .material-symbols-outlined{font-size:18px;}
.mic-btn.rec{background:var(--error);color:#fff;animation:micpulse 1s infinite;}
@keyframes micpulse{0%,100%{transform:scale(1);}50%{transform:scale(1.12);}}
/* Bouton "Reformuler" (IA) : a cote du micro sur les champs dictes. */
.reform-btn{border:0;background:var(--tertiary-container);color:var(--tertiary);border-radius:50%;width:30px;height:30px;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;vertical-align:middle;margin-left:6px;}
.reform-btn .material-symbols-outlined{font-size:18px;}
.reform-btn.busy{opacity:.7;cursor:default;animation:micpulse 1s infinite;}
.reform-btn.done{background:var(--ok-container);color:var(--ok);}
.reform-btn:disabled{cursor:default;}
/* Indicateur hors-ligne (auto). */
.net-badge{position:fixed;top:0;left:0;right:0;z-index:70;display:none;align-items:center;justify-content:center;gap:8px;
  background:var(--warn);color:#fff;font-size:13px;font-weight:500;padding:7px 12px;}
.net-badge.show{display:flex;}
.net-badge .material-symbols-outlined{font-size:18px;}
/* File d'attente d'envoi (actions faites hors-ligne, a renvoyer). */
.pending-badge{position:fixed;left:50%;bottom:150px;transform:translateX(-50%) translateY(8px);z-index:60;display:none;align-items:center;gap:8px;
  background:var(--warn);color:#fff;font-size:13px;font-weight:500;padding:8px 14px;border-radius:20px;box-shadow:0 3px 14px rgba(0,0,0,.28);cursor:pointer;opacity:0;transition:opacity .2s,transform .2s;}
.pending-badge.show{display:flex;opacity:1;transform:translateX(-50%) translateY(0);}
.pending-badge .material-symbols-outlined{font-size:18px;}
/* Invite "nouvelle version de l'app dispo". */
.update-banner{position:fixed;left:50%;bottom:200px;transform:translateX(-50%) translateY(10px);z-index:62;display:none;align-items:center;gap:8px;border:0;cursor:pointer;
  background:var(--primary);color:var(--on-primary);font:inherit;font-size:14px;font-weight:500;padding:11px 18px;border-radius:22px;box-shadow:0 4px 16px rgba(0,0,0,.3);opacity:0;transition:opacity .2s,transform .2s;}
.update-banner.show{display:flex;opacity:1;transform:translateX(-50%) translateY(0);}
.update-banner .material-symbols-outlined{font-size:20px;}
/* Echec d'un envoi differe (file hors-ligne) -> l'utilisateur doit savoir. */
.failed-badge{position:fixed;left:50%;bottom:250px;transform:translateX(-50%) translateY(8px);z-index:64;display:none;align-items:center;gap:8px;
  background:var(--danger,#c62828);color:#fff;font-size:13px;font-weight:500;padding:9px 15px;border-radius:20px;box-shadow:0 3px 14px rgba(0,0,0,.3);cursor:pointer;opacity:0;transition:opacity .2s,transform .2s;max-width:90vw;}
.failed-badge.show{display:flex;opacity:1;transform:translateX(-50%) translateY(0);}
.failed-badge .material-symbols-outlined{font-size:18px;}

/* Palette de commandes (Cmd/Ctrl+K). */
.pal-back{position:fixed;inset:0;z-index:65;display:none;justify-content:center;align-items:flex-start;background:rgba(0,0,0,.45);padding:72px 16px 16px;}
.pal-back.open{display:flex;}
.pal-box{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--outline);border-radius:18px;box-shadow:0 8px 30px rgba(0,0,0,.3);overflow:hidden;max-height:70vh;display:flex;flex-direction:column;}
.pal-search{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--outline);}
.pal-search .material-symbols-outlined{color:var(--primary);}
.pal-search input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:15px;color:var(--on-surface);}
.pal-list{overflow-y:auto;padding:6px;}
.pal-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;text-decoration:none;color:var(--on-surface);font-size:14px;font-weight:500;}
.pal-item:hover,.pal-item.sel{background:var(--surface-2);}
.pal-item .material-symbols-outlined{font-size:20px;color:var(--primary);}
.pal-empty{padding:16px;text-align:center;color:var(--on-surface-variant);font-size:14px;}

/* Bouton "retour" flottant (au pouce, bas-gauche) sur les ecrans de detail. */
.back-fab{position:fixed;left:max(16px,calc(50% - 240px + 16px));bottom:24px;z-index:40;width:48px;height:48px;border:1px solid var(--outline);border-radius:16px;
  background:var(--surface);color:var(--on-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);transition:transform .15s;}
.back-fab:active{transform:scale(.95);}
.back-fab .material-symbols-outlined{font-size:24px;}

/* Widget assistant flottant ("coach") sur les ecrans de detail. */
.coach-fab{position:fixed;right:max(16px,calc(50% - 240px + 16px));bottom:24px;z-index:40;width:52px;height:52px;border:0;border-radius:16px;
  background:var(--tertiary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.25);transition:transform .15s;}
.coach-fab:active{transform:scale(.95);}
.coach-fab .material-symbols-outlined{font-size:26px;}
.coach-sheet-back{position:fixed;inset:0;z-index:58;display:none;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.45);}
.coach-sheet-back.open{display:flex;}
.coach-sheet{background:var(--bg);width:100%;max-width:480px;border-radius:24px 24px 0 0;padding:16px 16px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -4px 24px rgba(0,0,0,.22);}
.coach-sheet-h{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.coach-sheet-h strong{flex:1;font-size:17px;font-weight:500;}
.coach-sheet-h>.material-symbols-outlined{color:var(--tertiary);}

/* Galerie des photos deja attachees a une intervention. */
.photo-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.gal-thumb{display:block;aspect-ratio:1;border-radius:12px;overflow:hidden;background:var(--surface-2);border:1px solid var(--outline);}
.gal-thumb img{width:100%;height:100%;object-fit:cover;display:block;}

/* Galerie photos (apercu + legende avant envoi). */
.photo-grid{display:flex;flex-direction:column;gap:10px;margin:4px 0 6px;}
.photo-item{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--outline);border-radius:12px;padding:8px;}
.photo-item img{width:64px;height:64px;object-fit:cover;border-radius:8px;flex:0 0 auto;background:var(--surface-2);}
.photo-item input{flex:1;min-width:0;border:1px solid var(--outline);border-radius:10px;padding:9px 12px;font:inherit;font-size:14px;background:var(--surface);color:var(--on-surface);}

/* Badge "brouillon" (autosave hors-ligne) : pastille discrete en bas a gauche. */
.draft-badge{position:fixed;left:12px;bottom:92px;z-index:55;background:var(--surface);color:var(--on-surface-variant);
  border:1px solid var(--outline);padding:7px 13px;border-radius:18px;font-size:12px;font-weight:500;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:6px;opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s;pointer-events:none;}
.draft-badge.show{opacity:1;transform:none;}
.draft-badge .material-symbols-outlined{color:var(--ok);}
.seg,.send{display:flex;gap:10px;}
.seg button,.send button{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--outline);
  background:var(--surface);color:var(--on-surface);border-radius:14px;padding:12px;font:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:.12s;}
.seg button.sel{background:var(--primary-container);color:var(--on-primary-container);border-color:transparent;}
.seg button:active,.send button:active{transform:scale(.97);}
.seg .material-symbols-outlined,.send .material-symbols-outlined{font-size:19px;}
.send .material-symbols-outlined{color:var(--primary);}

/* FAB */
.fab-wrap{position:fixed;right:max(16px,calc(50% - 240px + 16px));bottom:92px;z-index:20;
  display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.mini{display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(8px) scale(.9);pointer-events:none;transition:.18s;}
.fab-wrap.open .mini{opacity:1;transform:none;pointer-events:auto;}
.mini .l{background:var(--surface);color:var(--on-surface);border:1px solid var(--outline);padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:var(--shadow);}
.mini b{width:46px;height:46px;border-radius:14px;background:var(--surface);border:1px solid var(--outline);color:var(--primary);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);}
.fab{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:var(--on-primary);border:0;border-radius:18px;cursor:pointer;box-shadow:0 4px 12px rgba(11,87,208,.32);transition:transform .15s;}
.fab-wrap.open .fab .material-symbols-outlined{transform:rotate(45deg);}
.fab .material-symbols-outlined{font-size:26px;transition:transform .2s;}
.fab:active{transform:scale(.96);}

/* Barre du bas (nav) + barre d'action (CTA) */
.nav,.bottombar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--outline);z-index:15;}
.nav-inner{max-width:480px;margin:0 auto;display:flex;justify-content:space-around;padding:8px 4px 12px;}
.nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--on-surface-variant);font-size:11px;font-weight:500;cursor:pointer;}
.nav .ind{padding:4px 16px;border-radius:18px;transition:background .15s;display:flex;}
.nav a.active{color:var(--primary);}
.nav a.active .ind{background:var(--primary-container);}
.nav .material-symbols-outlined{font-size:23px;}
.bottombar .inner{max-width:480px;margin:0 auto;padding:12px 16px calc(12px + env(safe-area-inset-bottom));}
.cta{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;border:0;cursor:pointer;background:var(--primary);color:var(--on-primary);border-radius:18px;padding:15px;font:inherit;font-size:16px;font-weight:500;transition:transform .12s;}
.cta:active{transform:scale(.98);}

.reveal{opacity:0;transform:translateY(10px);animation:up .5s forwards;}
@keyframes up{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none;}}

/* Compléments écrans (tâches terminées, listes) */
.row.done .main strong{text-decoration:line-through;color:var(--on-surface-variant);}
.row .badge-pay{font-size:12px;font-weight:500;padding:3px 10px;border-radius:20px;}
.pay-ok{background:var(--ok-container);color:var(--ok);}
.pay-no{background:var(--error-container);color:var(--error);}

/* Chat des assistants (overlay plein ecran). */
.chat-overlay{position:fixed;inset:0;z-index:50;display:none;flex-direction:column;background:var(--bg);}
.chat-overlay.open{display:flex;}
.chat-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--outline);background:var(--surface);}
.chat-head strong{flex:1;font-size:16px;font-weight:500;}
.chat-warn{font-size:12px;color:var(--on-surface-variant);padding:8px 16px;background:var(--surface-2);border-bottom:1px solid var(--outline);}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;}
.chat-msg{max-width:84%;padding:10px 13px;border-radius:16px;font-size:14px;line-height:1.45;white-space:pre-wrap;word-wrap:break-word;}
.chat-msg.user{align-self:flex-end;background:var(--primary);color:var(--on-primary);border-bottom-right-radius:4px;}
.chat-msg.bot{align-self:flex-start;background:var(--surface);border:1px solid var(--outline);border-bottom-left-radius:4px;}
.chat-msg.bot a{color:var(--primary);}
.chat-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--outline);background:var(--surface);}
.chat-bar input{flex:1;border:1px solid var(--outline);border-radius:22px;padding:11px 16px;font:inherit;font-size:14px;background:var(--bg);color:var(--on-surface);}
.chat-bar button{flex:0 0 auto;width:44px;border:0;border-radius:50%;background:var(--primary);color:var(--on-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.chat-bar button:disabled{opacity:.5;cursor:default;}
/* Actions sous une reponse d'agent (copier/partager/SMS/mail/regenerer). */
.chat-actions{align-self:flex-start;display:flex;gap:4px;margin:-4px 0 4px 2px;}
.chat-actions button{border:0;background:transparent;color:var(--on-surface-variant);width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;}
.chat-actions button:active{background:var(--surface-2);}
.chat-actions .material-symbols-outlined{font-size:18px;}
/* Historique des conversations (liste dans la zone du chat). */
.chat-hist-title{font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--on-surface-variant);margin:4px 2px 6px;}
.chat-hist-empty{color:var(--on-surface-variant);font-size:14px;padding:16px 4px;text-align:center;}
.chat-hist-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--outline);
  border-radius:12px;padding:12px;font:inherit;color:var(--on-surface);cursor:pointer;}
.chat-hist-item:active{transform:scale(.99);}
.chat-hist-prev{flex:1;min-width:0;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.chat-hist-ago{font-size:12px;color:var(--on-surface-variant);flex:0 0 auto;}

/* SMS — feuille de modeles partagee (theme.js : lnpcSmsPicker). */
.sms-overlay{position:fixed;inset:0;z-index:60;display:none;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.45);}
.sms-overlay.open{display:flex;}
.sms-sheet{background:var(--bg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;
  border-radius:24px 24px 0 0;padding:16px 16px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -4px 24px rgba(0,0,0,.22);
  animation:smsup .25s ease;}
@keyframes smsup{from{transform:translateY(24px);opacity:.6;}to{transform:none;opacity:1;}}
.sms-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.sms-head>strong{flex:1;font-size:17px;font-weight:500;}
.sms-head>.material-symbols-outlined{color:var(--primary);}
.sms-ctx{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.sms-ctx-tag{font-size:12px;background:var(--surface-2);color:var(--on-surface-variant);padding:4px 10px;border-radius:14px;}
.sms-edit{width:100%;border:1px solid var(--outline);border-radius:14px;padding:12px 14px;font:inherit;font-size:14px;
  background:var(--surface);color:var(--on-surface);resize:vertical;margin-bottom:10px;}
.sms-send{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  background:var(--primary);color:var(--on-primary);border-radius:16px;padding:13px;font:inherit;font-size:15px;font-weight:500;transition:transform .12s;}
.sms-send:active{transform:scale(.98);}
.sms-send .material-symbols-outlined{font-size:20px;}
.sms-list-title{font-size:13px;font-weight:500;letter-spacing:.4px;text-transform:uppercase;
  color:var(--on-surface-variant);margin:18px 2px 10px;}
.sms-list{display:flex;flex-direction:column;gap:8px;}
.sms-tpl{display:flex;align-items:flex-start;gap:12px;text-align:left;width:100%;background:var(--surface);
  border:1px solid var(--outline);border-radius:14px;padding:12px;cursor:pointer;font:inherit;color:var(--on-surface);
  transition:transform .12s,box-shadow .12s;}
.sms-tpl:active{transform:scale(.98);}
.sms-tpl.suggested{border-color:var(--primary);}
.sms-tpl.sel{border-color:var(--primary);background:var(--primary-container);color:var(--on-primary-container);}
.sms-tpl-ic{font-size:22px;line-height:1.2;flex:0 0 auto;}
.sms-tpl-body{display:flex;flex-direction:column;gap:3px;min-width:0;}
.sms-tpl-title{font-size:14px;font-weight:500;}
.sms-tpl-title em{font-style:normal;color:var(--primary);font-weight:500;}
.sms-tpl.sel .sms-tpl-title em{color:inherit;}
.sms-tpl-prev{font-size:13px;color:var(--on-surface-variant);line-height:1.4;}
.sms-tpl.sel .sms-tpl-prev{color:inherit;opacity:.92;}
