:root{--bleu: #1f3a5f;--bleu-clair: #2f5a8f;--gris: #f4f6f8;--rouge: #c0392b;--vert: #1e8449}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--gris);color:#1c2733}.ecran-centre{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.carte{width:100%;max-width:380px;background:#fff;border-radius:14px;box-shadow:0 8px 30px #00000014;padding:2rem 1.75rem;display:flex;flex-direction:column}h1{margin:0;font-size:1.5rem;color:var(--bleu);text-align:center}.sous-titre{text-align:center;color:#5a6b7b;margin:.25rem 0 1.5rem}label{font-size:.85rem;font-weight:600;margin-bottom:.35rem;margin-top:.75rem}input{padding:.7rem .8rem;border:1px solid #cdd6df;border-radius:8px;font-size:1rem}input:focus{outline:none;border-color:var(--bleu-clair);box-shadow:0 0 0 3px #2f5a8f26}button{margin-top:1.25rem;padding:.75rem;background:var(--bleu);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}button:hover:not(:disabled){background:var(--bleu-clair)}button:disabled{opacity:.6;cursor:default}.lien{margin-top:1rem;text-align:center;color:var(--bleu-clair);font-size:.9rem;text-decoration:none}.lien:hover{text-decoration:underline}.erreur{color:var(--rouge);font-size:.9rem;margin:.75rem 0 0}.succes{color:var(--vert);font-size:.9rem;margin:.75rem 0 0}.note-socle{background:var(--gris);border-radius:8px;padding:.75rem;font-size:.85rem;color:#5a6b7b}.app{min-height:100vh}.barre{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:1rem;background:var(--bleu);color:#fff;padding:.6rem 1rem;padding-top:calc(.6rem + env(safe-area-inset-top))}.marque{font-weight:700;font-size:1.1rem}.nav{display:flex;gap:.25rem;flex:1;overflow-x:auto}.nav a{color:#cfe0f3;text-decoration:none;padding:.35rem .6rem;border-radius:6px;white-space:nowrap;font-size:.92rem}.nav a.actif,.nav a:hover{background:#ffffff26;color:#fff}.barre-droite{display:flex;align-items:center;gap:.5rem}.lien-bouton{background:none;border:none;color:#cfe0f3;cursor:pointer;margin:0;padding:.3rem .5rem;font-size:.9rem}.lien-bouton:hover{color:#fff;background:none}.contenu{max-width:900px;margin:0 auto;padding:1rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom))}.titre-ligne{display:flex;align-items:center;justify-content:space-between}.titre-ligne button{margin:0;padding:.5rem .9rem}h2{color:var(--bleu)}h3{color:var(--bleu);margin-top:0}.carte.form-large,section.carte{max-width:none;margin:1rem 0;align-items:stretch}.grille2{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem}.grille2>div{display:flex;flex-direction:column}.liste{list-style:none;padding:0}.carte-ligne{background:#fff;border-radius:10px;padding:.8rem 1rem;margin-bottom:.5rem;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000000d}.meta{color:#5a6b7b;font-size:.85rem}.vide{color:#8a99a8;font-style:italic;padding:.5rem 0}.recherche{display:flex;gap:.5rem;margin:.75rem 0}.recherche input{flex:1}.recherche button{margin:0}.grille-produits{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.carte-produit{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.carte-produit a{display:flex;flex-direction:column;text-decoration:none;color:inherit;padding-bottom:.6rem}.vignette{aspect-ratio:1;background:var(--gris);display:flex;align-items:center;justify-content:center;font-size:2rem}.vignette img{width:100%;height:100%;object-fit:cover}.carte-produit strong{padding:.5rem .6rem 0;font-size:.95rem}.carte-produit .meta{padding:0 .6rem}.bouton-fichier{display:inline-block;background:var(--gris);border:1px dashed #aab7c4;padding:.7rem;border-radius:8px;text-align:center;cursor:pointer;font-weight:600;color:var(--bleu);margin:.5rem 0}.photos{display:flex;flex-wrap:wrap;gap:.6rem}.photo{width:120px}.photo img{width:120px;height:120px;object-fit:cover;border-radius:8px;border:2px solid transparent}.photo.principale img{border-color:var(--bleu)}.photo-actions{display:flex;gap:.25rem;margin-top:.25rem}.photo-actions button{margin:0;padding:.25rem .4rem;font-size:.75rem}button.danger{background:var(--rouge)}.tableau{width:100%;border-collapse:collapse;margin-bottom:.75rem}.tableau th,.tableau td{text-align:left;padding:.4rem .5rem;border-bottom:1px solid #eef2f5;font-size:.9rem}.tableau th{color:#5a6b7b;font-weight:600}.form-inline{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.form-inline input,.form-inline select{width:auto;flex:1;min-width:90px}.form-inline button{margin:0}.bascule{display:flex;align-items:center;gap:.5rem;font-weight:500;margin:.4rem 0}.bascule input{width:auto}.cartes-stats{display:flex;gap:1rem;margin:1rem 0}.carte.stat{flex:1;max-width:none;align-items:center;text-decoration:none;color:var(--bleu);padding:1.2rem}.carte.stat .chiffre{font-size:2rem;font-weight:700}.cloche{position:relative}.cloche-bouton{background:none;border:none;font-size:1.3rem;cursor:pointer;margin:0;padding:.2rem;position:relative}.cloche-bouton:hover{background:none}.pastille{position:absolute;top:-2px;right:-4px;background:var(--rouge);color:#fff;font-size:.65rem;border-radius:10px;padding:0 .3rem}.cloche-panneau{position:absolute;right:0;top:2.4rem;width:300px;max-width:85vw;background:#fff;color:#1c2733;border-radius:10px;box-shadow:0 8px 30px #0003;padding:.75rem}.cloche-entete{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.cloche-entete .lien-bouton{color:var(--bleu-clair)}.cloche-liste{list-style:none;padding:0;margin:0;max-height:50vh;overflow-y:auto}.cloche-liste li{padding:.5rem;border-radius:6px;font-size:.85rem}.cloche-liste li.non-lu{background:#eef4fb}.cloche-liste li.lu{opacity:.65}.banniere-hors-ligne{background:#fff4e5;color:#8a5a00;border:1px solid #f0c987;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;margin:.5rem 0}.badge-attente{display:inline-block;background:#f0c987;color:#6b4500;font-size:.65rem;font-weight:700;border-radius:8px;padding:.05rem .4rem;margin-left:.5rem;vertical-align:middle}.lien-desactive{display:flex;flex-direction:column;padding-bottom:.6rem;opacity:.8}.sync{font-size:.85rem;margin:0;padding:.25rem .5rem}.sync.ok{color:#7fe0a3;background:none;border:none;font-size:.7rem}button.sync{border:none;border-radius:6px;cursor:pointer}button.sync.attente{background:#e8a13a;color:#fff}button.sync.horsligne{background:var(--rouge);color:#fff}textarea{padding:.7rem .8rem;border:1px solid #cdd6df;border-radius:8px;font-size:1rem;font-family:inherit}select{padding:.7rem .8rem;border:1px solid #cdd6df;border-radius:8px;font-size:1rem;background:#fff}
