:root{--noir: #1a1a1a;--graphite: #232323;--graphite-2: #2e2e2e;--acier: #3a3a3a;--beton: #f4f1ec;--beton-2: #e7e3da;--blanc: #ffffff;--texte: #1a1a1a;--texte-doux: #7a746b;--rouge: #c41020;--rouge-fonce: #a00d1a;--ok: #2e7d4f;--alerte: #c0392b;--info: #2b6cb0;--r: 12px;--r-sm: 8px;--ombre: 0 2px 0 rgba(0,0,0,.16), 0 6px 18px rgba(26,26,26,.1);--tap: 52px;--font-display: "Archivo Black", "Arial Black", sans-serif;--font-titre: "DM Sans", system-ui, sans-serif;--font-corps: "DM Sans", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{font-family:var(--font-corps);color:var(--texte);background:var(--beton);font-size:16px;line-height:1.45;overscroll-behavior-y:none}h1,h2,h3,.titre{font-family:var(--font-titre);font-weight:700;text-transform:uppercase;letter-spacing:.01em;line-height:1.1}.app{min-height:100%;display:flex;flex-direction:column;max-width:560px;margin:0 auto;background:var(--beton)}.entete{position:sticky;top:0;z-index:20;background:var(--noir);color:var(--blanc);padding:calc(env(safe-area-inset-top) + 14px) 18px 14px;display:flex;align-items:center;gap:10px;border-bottom:3px solid var(--rouge)}.entete .marque{font-family:var(--font-display);font-size:15px;letter-spacing:.01em;display:flex;align-items:center;gap:9px}.entete .plot{width:8px;height:20px;background:var(--rouge);border-radius:2px}.entete .titre-page{margin-left:auto;font-family:var(--font-titre);font-weight:700;font-size:13px;color:var(--rouge);text-transform:uppercase;letter-spacing:.07em}.contenu{flex:1;padding:18px 16px calc(96px + env(safe-area-inset-bottom));animation:monte .28s ease both}@keyframes monte{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.section-titre{font-size:13px;color:var(--texte-doux);text-transform:uppercase;letter-spacing:.09em;font-family:var(--font-titre);font-weight:700;margin:22px 2px 10px}.carte{background:var(--blanc);border-radius:var(--r);border:1px solid var(--beton-2);box-shadow:var(--ombre);padding:16px;margin-bottom:12px}.carte-lien{display:block;text-decoration:none;color:inherit;position:relative;border-left:4px solid var(--rouge);border-radius:0 var(--r) var(--r) 0;transition:transform .08s ease}.carte-lien:active{transform:scale(.99)}.ligne{display:flex;align-items:center;gap:12px}.entre{justify-content:space-between}.pousse{margin-left:auto}.numero-dossier{font-family:var(--font-display);font-size:19px;letter-spacing:.01em}.sous{color:var(--texte-doux);font-size:14px}.statut{display:inline-block;font-family:var(--font-titre);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:4px 9px;border-radius:100px;background:var(--graphite-2);color:var(--blanc)}.statut.prospect{background:#4a4a4a}.statut.visite{background:var(--info)}.statut.devis{background:#8a6d0e}.statut.signe{background:#2f855a}.statut.en_cours{background:var(--rouge);color:var(--blanc)}.statut.reception{background:var(--info)}.statut.sav{background:var(--alerte)}.statut.archive,.statut.perdu{background:#6b7280}.statut.client{background:var(--ok)}.grille-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat{background:var(--graphite);color:var(--blanc);border-radius:var(--r);padding:16px;position:relative;overflow:hidden}.stat .chiffre{font-family:var(--font-display);font-size:36px;line-height:1}.stat .label{font-size:13px;color:#b5aea4;text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-weight:600}.stat.accent{background:var(--rouge);color:var(--blanc)}.stat.accent .label{color:#f3c9cc}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap);padding:0 20px;font-family:var(--font-titre);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.04em;border:none;border-radius:var(--r);cursor:pointer;width:100%;background:var(--graphite);color:var(--blanc);transition:transform .08s ease,filter .15s ease}.btn:active{transform:scale(.98)}.btn-primaire{background:var(--rouge);color:var(--blanc)}.btn-primaire:disabled{background:var(--beton-2);color:var(--texte-doux)}.btn-ligne{background:transparent;color:var(--noir);border:2px solid var(--acier)}.btn-petit{min-height:42px;width:auto;padding:0 14px;font-size:14px}.bouton-icone{background:none;border:none;color:var(--blanc);width:44px;height:44px;display:grid;place-items:center;cursor:pointer}.champ{margin-bottom:14px}.champ label{display:block;font-size:13px;font-weight:600;color:var(--texte-doux);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.champ input,.champ select,.champ textarea{width:100%;min-height:var(--tap);padding:12px 14px;font-family:var(--font-corps);font-size:16px;border:2px solid var(--beton-2);border-radius:var(--r-sm);background:var(--blanc);color:var(--texte)}.champ input:focus,.champ select:focus,.champ textarea:focus{outline:none;border-color:var(--rouge)}.champ textarea{min-height:96px;resize:vertical}.deux-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px}.puces{display:flex;flex-wrap:wrap;gap:8px}.puce{padding:8px 12px;border-radius:100px;border:2px solid var(--beton-2);background:var(--blanc);font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.puce.active{background:var(--noir);color:var(--blanc);border-color:var(--noir)}.nav-basse{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:560px;background:var(--noir);display:flex;padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:30;border-top:1px solid #000}.nav-basse a{flex:1;text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:#8a847b;padding:6px 0;border-radius:var(--r-sm);font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-titre);font-weight:700}.nav-basse a.actif{color:var(--rouge)}.nav-basse a.actif svg{stroke:var(--rouge)}.fab{position:fixed;right:max(16px,calc(50% - 264px));bottom:calc(78px + env(safe-area-inset-bottom));width:60px;height:60px;border-radius:50%;background:var(--rouge);color:var(--blanc);border:none;box-shadow:0 6px 16px #0000004d;font-size:30px;display:grid;place-items:center;cursor:pointer;z-index:31}.fab:active{transform:scale(.95)}.vide{text-align:center;color:var(--texte-doux);padding:48px 16px}.vide .gros{font-family:var(--font-titre);font-weight:700;font-size:18px;text-transform:uppercase;color:var(--acier)}.erreur-msg{background:#fdecec;color:var(--alerte);border:1px solid #f5c6c6;padding:12px 14px;border-radius:var(--r-sm);margin-bottom:14px;font-weight:600}.chargement{display:grid;place-items:center;padding:60px 0}.spin{width:34px;height:34px;border-radius:50%;border:4px solid var(--beton-2);border-top-color:var(--rouge);animation:tourne .8s linear infinite}@keyframes tourne{to{transform:rotate(360deg)}}.retour{background:none;border:none;color:var(--rouge);font-family:var(--font-titre);font-weight:700;text-transform:uppercase;font-size:14px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;padding:0;letter-spacing:.04em}.connexion{min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:28px;max-width:420px;margin:0 auto;background:radial-gradient(900px 500px at 80% -10%,rgba(196,16,32,.12),transparent),var(--noir);color:var(--blanc)}.connexion .marque-bar{width:44px;height:7px;background:var(--rouge);border-radius:2px;margin-bottom:16px}.connexion .logo{font-family:var(--font-display);font-size:30px;line-height:1.04;color:var(--blanc)}.connexion .logo .rouge{color:var(--rouge)}.connexion .accroche{color:#8a847b;margin:10px 0 30px;text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-family:var(--font-titre);font-weight:700}.connexion .champ label{color:#8a847b}.connexion .champ input{background:var(--graphite);border-color:var(--acier);color:var(--blanc)}.galerie{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.vignette{position:relative;padding:0;border:none;cursor:pointer;aspect-ratio:1 / 1;border-radius:var(--r-sm);overflow:hidden;background:var(--beton-2)}.vignette img{width:100%;height:100%;object-fit:cover;display:block}.vref{position:absolute;left:4px;bottom:4px;font-family:var(--font-titre);font-weight:700;font-size:10px;letter-spacing:.03em;background:#1a1a1ad1;color:var(--rouge);padding:1px 6px;border-radius:4px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#000000ed;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px}.lightbox img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:6px}.lb-info{color:#fff;font-family:var(--font-titre);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:14px}.lb-fermer{color:#8a847b;font-size:12px;margin-top:6px}.champ-adresse{position:relative}.suggestions{list-style:none;margin:6px 0 0;padding:4px;position:absolute;z-index:40;left:0;right:0;background:var(--blanc);border:1px solid var(--beton-2);border-radius:var(--r-sm);box-shadow:var(--ombre);max-height:250px;overflow-y:auto}.suggestions li{padding:11px 12px;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:2px}.suggestions li:hover,.suggestions li:active{background:var(--beton)}.suggestions .sugg-nom{font-weight:600;color:var(--texte)}.suggestions .sugg-ctx{font-size:13px;color:var(--texte-doux)}.lien-action{background:none;border:none;padding:4px 0;cursor:pointer;font-family:var(--font-titre);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;color:var(--info)}.lien-action.danger{color:var(--rouge)}.lb-suppr{background:var(--rouge);color:#fff;width:auto}.lb-actions{display:flex;gap:10px;margin-top:16px}.lb-actions .btn{width:auto}.lb-actions .btn-ligne{color:#fff;border-color:#ffffff80}.toile-wrap{border:2px solid var(--beton-2);border-radius:var(--r-sm);overflow:hidden;background:#fff}.toile-barre{display:flex;align-items:center;gap:8px;padding:9px 10px;background:var(--graphite);flex-wrap:wrap}.toile-couleur{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.35);cursor:pointer;padding:0}.toile-couleur.active{border-color:#fff;transform:scale(1.12)}.toile-taille{width:32px;height:28px;border-radius:6px;background:#2e2e2e;border:2px solid transparent;cursor:pointer;display:grid;place-items:center}.toile-taille.active{border-color:#fff}.toile-action{background:#2e2e2e;color:#fff;border:none;border-radius:6px;padding:7px 11px;font-family:var(--font-titre);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.toile{display:block;width:100%;touch-action:none;cursor:crosshair;background:#fff}.mini-liens{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.mini-vignette{position:relative;width:56px;height:56px;border-radius:6px;overflow:hidden;background:var(--beton-2)}.mini-vignette img{width:100%;height:100%;object-fit:cover;display:block}.mini-ref{position:absolute;left:2px;bottom:2px;font-size:9px;font-weight:700;background:#1a1a1ad1;color:#fff;padding:0 3px;border-radius:3px}.mini-x{position:absolute;top:2px;right:2px;width:18px;height:18px;border:none;border-radius:50%;background:var(--rouge);color:#fff;font-size:13px;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0}.lier-picker{margin-top:10px;padding:10px;background:var(--beton);border:1px solid var(--beton-2);border-radius:var(--r-sm)}.tache-input{flex:1;min-height:44px;padding:10px 12px;border:2px solid var(--beton-2);border-radius:var(--r-sm);background:var(--blanc);font-size:16px;font-family:var(--font-corps)}.tache-input:focus{outline:none;border-color:var(--rouge)}.tache{display:flex;align-items:center;gap:10px;background:var(--blanc);border:1px solid var(--beton-2);border-radius:var(--r-sm);padding:10px 12px;margin-bottom:8px}.tache.faite .tache-titre{text-decoration:line-through;color:var(--texte-doux)}.tache-coche{width:26px;height:26px;flex:0 0 auto;border:2px solid var(--acier);border-radius:6px;background:#fff;cursor:pointer;display:grid;place-items:center;font-weight:900;color:var(--ok);font-size:16px;line-height:1}.tache.faite .tache-coche{background:var(--ok);border-color:var(--ok);color:#fff}.tache-titre{flex:1}.tache-suppr{width:26px;height:26px;flex:0 0 auto;border:none;background:none;color:var(--texte-doux);font-size:20px;line-height:1;cursor:pointer}.toile-aide{font-size:12px;color:var(--texte-doux);padding:8px 10px;background:var(--beton);border-top:1px solid var(--beton-2)}.af-liste{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}.af-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:var(--beton);border:1px solid var(--beton-2);border-radius:12px;text-decoration:none;color:var(--texte)}.af-item:active{background:var(--beton-2)}.af-txt{min-width:0}.af-titre{font-weight:600;font-size:15px}.af-dossier{font-size:12px;color:var(--texte-doux);margin-top:2px}.af-ech{flex:none;font-size:13px;font-weight:700;color:var(--texte-doux);background:var(--beton-2);padding:4px 9px;border-radius:999px}.af-retard{color:#fff;background:var(--rouge)}.toile-selbarre{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 10px;background:#fff5f5;border-bottom:1px solid var(--beton-2)}.toile-sel-label{font-size:12px;font-weight:700;color:var(--rouge);margin-right:auto}.tache-date-ajout{margin-top:8px;width:100%;min-height:42px;padding:8px 12px;border:2px solid var(--beton-2);border-radius:var(--r-sm);background:var(--blanc);font-size:16px;font-family:var(--font-corps);color:var(--texte)}.tache-ech-wrap{position:relative;display:inline-flex;flex:0 0 auto}.tache-ech{font-size:12px;font-weight:700;color:var(--texte-doux);background:var(--beton-2);padding:5px 10px;border-radius:999px;white-space:nowrap}.tache-ech-retard{color:#fff;background:var(--rouge)}.tache-ech-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%}.filtres-barre{display:flex;gap:8px;margin-bottom:14px}.recherche{flex:1;min-width:0;min-height:44px;padding:10px 14px;border:2px solid var(--beton-2);border-radius:var(--r-sm);background:var(--blanc);font-size:16px;font-family:var(--font-corps)}.recherche:focus{outline:none;border-color:var(--rouge)}.filtre-statut{flex:0 0 auto;max-width:42%;min-height:44px;padding:8px 10px;border:2px solid var(--beton-2);border-radius:var(--r-sm);background:var(--blanc);font-size:15px;font-family:var(--font-corps);color:var(--texte)}.partage-fond{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000}.partage-feuille{width:100%;max-width:480px;background:var(--blanc);border-radius:18px 18px 0 0;padding:14px 14px calc(14px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:8px}.partage-titre{font-weight:800;font-size:16px;text-align:center;padding:6px 0 4px;color:var(--texte)}.partage-opt{width:100%;text-align:left;padding:14px 16px;border:1px solid var(--beton-2);border-radius:12px;background:var(--beton);font-size:16px;font-family:var(--font-corps);color:var(--texte);cursor:pointer}.partage-opt:active{background:var(--beton-2)}.partage-opt.annul{text-align:center;font-weight:700;color:var(--texte-doux);background:transparent;border:none}.onglets{display:flex;gap:4px;margin:16px 0 14px;background:var(--beton);border:1px solid var(--beton-2);border-radius:12px;padding:4px;overflow-x:auto}.onglet{flex:1 0 auto;padding:9px 14px;border:none;background:transparent;border-radius:9px;font:600 14px var(--font-corps);color:var(--texte-doux);cursor:pointer;white-space:nowrap}.onglet.actif{background:var(--blanc);color:var(--rouge);box-shadow:0 1px 3px #00000014}.resume{display:flex;flex-direction:column;gap:12px}.resume-action{background:var(--rouge);color:#fff;border-radius:14px;padding:14px 16px}.resume-action-label{font-size:11px;opacity:.85;text-transform:uppercase;letter-spacing:.5px}.resume-action-val{font-size:18px;font-weight:800;margin-top:2px;font-family:var(--font-titre)}.resume-grille{display:grid;grid-template-columns:1fr 1fr;gap:12px}.resume-bloc{background:var(--beton);border:1px solid var(--beton-2);border-radius:14px;padding:12px 14px}.resume-bloc-t{font-size:11px;font-weight:800;color:var(--rouge);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.resume-tache,.resume-mesure{font-size:14px;padding:3px 0}.resume-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
