:root{
    --orange:#F94E12; --orange-dark:#D63E08; --orange-soft:#FDE7DC;
    --charcoal:#17130F; --charcoal-2:#2A241E; --bg:#F4F1EC; --card:#FFFFFF;
    --line:#E7E1D8; --muted:#8A8178; --text:#1E1813; --green:#2FA36B; --red:#C0392B;
  }
  *{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;font-family:inherit;}
  html,body{height:100%;}
  body{
    font-family:'Barlow',system-ui,sans-serif;color:var(--text);
    background:radial-gradient(1200px 600px at 50% -10%,#211a14,#14110d 55%,#0c0a07);
    display:flex;align-items:center;justify-content:center;padding:24px 12px;
  }
  .stage{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;}
  .stage-note{color:#cabfb2;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;text-align:center;max-width:360px;line-height:1.5;}
  .stage-note b{color:var(--orange);}

  .phone{width:392px;max-width:100%;height:812px;max-height:90vh;background:var(--bg);border-radius:46px;position:relative;overflow:hidden;box-shadow:0 0 0 11px #0a0805,0 0 0 13px #2c2620,0 40px 80px -20px rgba(0,0,0,.7);}
  .notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:118px;height:30px;background:#0a0805;border-radius:0 0 18px 18px;z-index:60;}
  .statusbar{position:absolute;top:0;left:0;right:0;height:48px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 26px 6px;font-size:13px;font-weight:700;z-index:55;color:#fff;pointer-events:none;}

  .screen{position:absolute;inset:0;display:none;flex-direction:column;}
  .screen.active{display:flex;}
  .scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;}
  .scroll::-webkit-scrollbar{display:none;}

  .mark{display:inline-block;color:var(--orange);}
  .mark svg{display:block;width:100%;height:100%;}

  /* LOGIN / ONBOARD */
  #login{background:linear-gradient(180deg,#17130F,#241c14);color:#fff;align-items:center;justify-content:center;padding:40px 34px;}
  #login .brand{display:flex;flex-direction:column;align-items:center;gap:20px;margin-top:-40px;animation:rise .7s ease both;}
  #login .mark{width:92px;height:92px;filter:drop-shadow(0 8px 24px rgba(249,78,18,.5));}
  #login .word{font-family:'Archivo';font-weight:900;font-size:38px;letter-spacing:.06em;}
  #login .tag{color:#b7ab9c;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;}
  #login .actions{position:absolute;bottom:50px;left:34px;right:34px;display:flex;flex-direction:column;gap:12px;animation:rise .7s .15s ease both;}
  .btn{border:none;border-radius:16px;padding:17px;font-family:'Archivo';font-weight:700;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:transform .12s,filter .12s;width:100%;}
  .btn:active{transform:scale(.97);}
  .btn-primary{background:var(--orange);color:#fff;}
  .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.16);}
  .btn-dark{background:var(--charcoal);color:#fff;}
  .btn[disabled]{opacity:.5;pointer-events:none;}
  #login .hint{text-align:center;color:#8a7f70;font-size:12px;margin-top:2px;}

  .topbar{background:var(--charcoal);color:#fff;padding:52px 18px 16px;display:flex;align-items:center;gap:13px;flex-shrink:0;}
  .topbar .mark{width:28px;height:28px;}
  .topbar h1{font-family:'Archivo';font-weight:800;font-size:21px;flex:1;}
  .iconbtn{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;border:none;color:#fff;cursor:pointer;font-size:17px;}
  .searchbar{background:var(--charcoal);padding:0 18px 16px;flex-shrink:0;}
  .searchbar input{width:100%;border:none;border-radius:13px;padding:12px 15px;background:rgba(255,255,255,.12);color:#fff;font-size:15px;}
  .searchbar input::placeholder{color:#b7ab9c;}

  .section-h{padding:16px 20px 8px;font-family:'Archivo';font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
  .empty{padding:50px 30px;text-align:center;color:var(--muted);}
  .empty .big{font-size:40px;margin-bottom:10px;}

  .card{background:var(--card);margin:0 14px 11px;border-radius:18px;padding:13px;display:flex;gap:13px;align-items:center;border:1px solid var(--line);cursor:pointer;transition:transform .12s;animation:rise .4s ease both;}
  .card:active{transform:scale(.985);}
  .thumb{width:56px;height:56px;border-radius:14px;flex-shrink:0;background-size:cover;background-position:center;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:20px;}
  .thumb .pin{position:absolute;bottom:3px;right:3px;width:18px;height:18px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff;font-size:9px;}
  .card .body{flex:1;min-width:0;}
  .card .row1{display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
  .card .name{font-family:'Archivo';font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .card .time{font-size:11.5px;color:var(--muted);flex-shrink:0;}
  .card .loc{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px;margin:2px 0 5px;}
  .card .last{display:flex;justify-content:space-between;align-items:center;gap:8px;}
  .card .preview{font-size:13px;color:#5e574e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;}
  .badge{background:var(--orange);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;}
  .status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}

  .detail-top{background:var(--charcoal);color:#fff;padding:52px 12px 0;flex-shrink:0;}
  .detail-top .head{display:flex;align-items:center;gap:9px;padding-bottom:11px;}
  .detail-top .back{background:none;border:none;color:#fff;cursor:pointer;font-size:26px;line-height:1;padding:0 4px;}
  .detail-top .ttl{flex:1;min-width:0;}
  .detail-top .ttl h2{font-family:'Archivo';font-weight:800;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .detail-top .ttl p{font-size:11.5px;color:#b7ab9c;}
  .tabs{display:flex;gap:2px;}
  .tab{flex:1;background:none;border:none;color:#b7ab9c;font-family:'Archivo';font-weight:700;font-size:12.5px;padding:11px 2px;cursor:pointer;position:relative;}
  .tab.active{color:#fff;}
  .tab.active::after{content:"";position:absolute;left:16%;right:16%;bottom:0;height:3px;background:var(--orange);border-radius:3px 3px 0 0;}
  .tabpane{display:none;}
  .tabpane.active{display:block;}

  .feed{padding:14px 14px 14px;}
  .daysep{text-align:center;font-size:11px;color:var(--muted);font-weight:600;margin:4px 0 12px;text-transform:uppercase;letter-spacing:.08em;}
  .msg{max-width:86%;margin-bottom:11px;animation:rise .35s ease both;}
  .msg .who{font-size:11.5px;font-weight:700;color:var(--orange);margin:0 0 3px 4px;}
  .bubble{background:#fff;border:1px solid var(--line);border-radius:4px 16px 16px 16px;padding:9px 12px;font-size:14.5px;line-height:1.45;word-wrap:break-word;}
  .bubble .meta{font-size:10px;color:var(--muted);text-align:right;margin-top:3px;}
  .msg.me{margin-left:auto;}
  .msg.me .bubble{background:var(--orange-soft);border-color:#f6cdb8;border-radius:16px 4px 16px 16px;}
  .msg.me .who{text-align:right;color:#b07a5a;}
  .photo-msg{padding:5px;}
  .photo-msg .pimg{width:100%;height:180px;object-fit:cover;object-position:center;border-radius:11px;background-color:#d8cfc2;}
  .photo-msg .cap{padding:7px 6px 1px;font-size:13.5px;}
  .geo{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--orange);font-weight:600;padding:4px 6px 0;}
  .report{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;}
  .report .rh{background:var(--charcoal);color:#fff;padding:9px 12px;display:flex;align-items:center;gap:8px;font-family:'Archivo';font-weight:700;font-size:12.5px;}
  .report .rh .ico{color:var(--orange);font-size:14px;}
  .report .rb{padding:11px 12px;font-size:13.5px;line-height:1.55;white-space:pre-wrap;}
  .report .pdf{display:flex;align-items:center;gap:7px;padding:10px 12px;border-top:1px solid var(--line);color:var(--orange);font-weight:600;font-size:13px;cursor:pointer;}

  .composer{position:absolute;left:0;right:0;bottom:0;background:var(--bg);border-top:1px solid var(--line);padding:9px 12px calc(9px + env(safe-area-inset-bottom));display:flex;align-items:center;gap:8px;}
  .composer .cbtn{width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px;}
  .composer .plus{background:var(--orange);color:#fff;box-shadow:0 6px 16px -4px rgba(249,78,18,.6);transition:transform .15s;}
  .composer .plus.rot{transform:rotate(45deg);}
  .composer .field{flex:1;background:#fff;border:1px solid var(--line);border-radius:24px;padding:0 6px 0 16px;display:flex;align-items:flex-end;}
  .composer .field input{flex:1;border:none;outline:none;padding:12px 0;font-size:14.5px;background:none;}
  .composer .field textarea{flex:1;border:none;outline:none;padding:11px 0;font-size:14.5px;background:none;resize:none;font-family:inherit;line-height:1.35;max-height:120px;overflow-y:auto;}
  .composer .send{background:none;color:var(--orange);border:none;font-size:22px;cursor:pointer;padding:0 8px 9px;}
  .composer .mic{background:#fff;border:1px solid var(--line);color:var(--charcoal);}

  .grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:14px;}
  .grid .g{aspect-ratio:1;border-radius:14px;background-size:cover;background-position:center;position:relative;overflow:hidden;background-color:#d8cfc2;}
  .grid .g .tag{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.65));color:#fff;font-size:10.5px;padding:14px 7px 6px;display:flex;align-items:center;gap:3px;}

  .doc{display:flex;align-items:center;gap:12px;background:#fff;margin:0 14px 9px;border:1px solid var(--line);border-radius:14px;padding:12px;cursor:pointer;}
  .doc .di{width:42px;height:42px;border-radius:11px;background:var(--orange-soft);color:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;}
  .doc .dn{font-weight:600;font-size:14.5px;}
  .doc .dm{font-size:12px;color:var(--muted);}

  .ai-bar{margin:12px 14px;background:linear-gradient(120deg,#17130F,#3a2c1e);border-radius:16px;padding:14px;color:#fff;display:flex;align-items:center;gap:12px;}
  .ai-bar .txt{flex:1;}
  .ai-bar .txt .t{font-family:'Archivo';font-weight:700;font-size:14px;}
  .ai-bar .txt .d{font-size:11.5px;color:#c6bab0;}
  .ai-bar button{background:var(--orange);color:#fff;border:none;border-radius:11px;padding:10px 14px;font-family:'Archivo';font-weight:700;font-size:13px;cursor:pointer;flex-shrink:0;}

  /* planning */
  .week{display:flex;gap:6px;padding:14px;overflow-x:auto;}
  .day{min-width:46px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:13px;padding:8px 0;}
  .day.sel{background:var(--orange);color:#fff;border-color:var(--orange);}
  .day .dd{font-family:'Archivo';font-weight:800;font-size:17px;}
  .day .dw{font-size:10.5px;opacity:.85;}
  .slot{background:#fff;margin:0 14px 9px;border:1px solid var(--line);border-radius:14px;padding:12px;border-left:4px solid var(--orange);}
  .slot .st{font-family:'Archivo';font-weight:700;font-size:12.5px;color:var(--orange);}
  .slot .sn{font-weight:600;font-size:15px;margin:2px 0;}

  .person{display:flex;align-items:center;gap:12px;background:#fff;margin:0 14px 9px;border:1px solid var(--line);border-radius:14px;padding:12px;}
  .person .pa{width:44px;height:44px;border-radius:50%;color:#fff;font-family:'Archivo';font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
  .person .pn{font-weight:600;font-size:15px;}
  .person .pr{font-size:12px;color:var(--muted);}
  .person .pstat{margin-left:auto;font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;}

  .nav{height:76px;background:#fff;border-top:1px solid var(--line);display:flex;padding-bottom:12px;flex-shrink:0;}
  .nav button{flex:1;background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:10.5px;font-weight:600;cursor:pointer;}
  .nav button.on{color:var(--orange);}
  .nav svg{width:22px;height:22px;}

  /* overlays */
  .ov-back{position:absolute;inset:0;background:rgba(20,15,10,.5);z-index:80;opacity:0;pointer-events:none;transition:opacity .25s;}
  .ov-back.open{opacity:1;pointer-events:auto;}
  .sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:26px 26px 0 0;padding:8px 16px 30px;z-index:81;transform:translateY(110%);opacity:0;pointer-events:none;transition:transform .3s cubic-bezier(.3,1,.4,1),opacity .25s;}
  .sheet.open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .grab{width:42px;height:5px;background:var(--line);border-radius:3px;margin:6px auto 12px;}
  .sh-title{font-family:'Archivo';font-weight:800;font-size:18px;margin:0 4px 10px;}
  .act{display:flex;align-items:center;gap:13px;padding:12px 6px;cursor:pointer;border-radius:14px;}
  .act:active{background:var(--bg);}
  .act .ai{width:46px;height:46px;border-radius:14px;background:var(--orange-soft);color:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px;}
  .act .at{font-family:'Archivo';font-weight:700;font-size:15px;}
  .act .ad{font-size:12px;color:var(--muted);}

  .modal{position:absolute;left:18px;right:18px;top:50%;transform:translateY(-50%) scale(.94);background:#fff;border-radius:22px;padding:22px;z-index:81;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;}
  .modal.open{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1);}
  .modal h3{font-family:'Archivo';font-weight:800;font-size:20px;margin-bottom:4px;}
  .modal p.sub{color:var(--muted);font-size:13px;margin-bottom:16px;}
  .modal label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;display:block;margin:12px 0 5px;}
  .modal input,.modal textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:13px;font-size:15px;background:var(--bg);}
  .modal textarea{resize:none;min-height:90px;line-height:1.5;}
  .modal .mrow{display:flex;gap:10px;margin-top:18px;}

  /* RAPPORT VOCAL */
  #rapport{background:linear-gradient(180deg,#17130F,#241c14);color:#fff;}
  #rapport .rtop{padding:52px 16px 0;display:flex;align-items:center;gap:8px;flex-shrink:0;}
  #rapport .rtop button{background:none;border:none;color:#fff;cursor:pointer;font-size:26px;}
  #rapport .rtop h2{font-family:'Archivo';font-weight:800;font-size:18px;}
  #rapport .rcenter{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:18px;overflow-y:auto;}
  #rapport .miccircle{width:120px;height:120px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .15s;}
  #rapport .miccircle.rec{animation:pulse 1.6s infinite;}
  #rapport .miccircle:active{transform:scale(.94);}
  #rapport .listening{color:#b7ab9c;font-size:13.5px;text-align:center;}
  #rapport .transcript{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px;width:100%;max-width:330px;font-size:14.5px;line-height:1.55;min-height:90px;}
  #rapport .transcript textarea{width:100%;background:none;border:none;color:#fff;font-size:14.5px;line-height:1.55;outline:none;resize:none;min-height:80px;}
  #rapport .ai-note{display:flex;align-items:center;gap:7px;color:var(--orange);font-size:12px;font-weight:600;text-align:center;}
  #rapport .rfoot{padding:0 16px calc(28px + env(safe-area-inset-bottom));flex-shrink:0;display:flex;flex-direction:column;gap:10px;}

  .spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block;}
  .spinner.dark{border-color:rgba(249,78,18,.25);border-top-color:var(--orange);}
  @keyframes spin{to{transform:rotate(360deg);}}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(249,78,18,.5);}70%{box-shadow:0 0 0 24px rgba(249,78,18,0);}100%{box-shadow:0 0 0 0 rgba(249,78,18,0);}}
  @keyframes rise{from{opacity:0;transform:translateY(9px);}to{opacity:1;transform:translateY(0);}}

  .toast{position:absolute;left:50%;bottom:96px;transform:translateX(-50%) translateY(20px);background:var(--charcoal);color:#fff;padding:11px 18px;border-radius:13px;font-size:13.5px;font-weight:600;z-index:90;opacity:0;transition:.25s;pointer-events:none;white-space:nowrap;}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

  @media(max-width:430px){
    body{padding:0;}
    .phone{width:100%;height:100vh;height:100dvh;max-height:none;border-radius:0;box-shadow:none;}
    .notch{display:none;}
    .stage-note{display:none;}
  }

/* ===== Ajouts v1.1 : lightbox, plans/documents, suppression, lisibilité ===== */

/* Lightbox photo plein écran + zoom */
.lightbox{position:absolute;inset:0;background:rgba(8,6,4,.96);z-index:4000;display:none;align-items:center;justify-content:center;}
.lightbox.open{display:flex;}
.lightbox .lb-stage{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;touch-action:none;}
.lightbox img{max-width:100%;max-height:100%;transform-origin:center center;user-select:none;-webkit-user-drag:none;will-change:transform;}
.lightbox .lb-close{position:absolute;top:max(16px,env(safe-area-inset-top));right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;border:none;font-size:19px;cursor:pointer;z-index:2;}
.lightbox .lb-cap{position:absolute;left:0;right:0;bottom:0;padding:16px 20px max(18px,env(safe-area-inset-bottom));color:#fff;font-size:13px;background:linear-gradient(transparent,rgba(0,0,0,.7));text-align:center;}

/* Bouton supprimer (admin) */
.delmsg{background:none;border:none;color:var(--red);font-size:14px;cursor:pointer;padding:0 2px;margin-left:8px;opacity:.85;}
.bubble .meta .delmsg{font-size:12px;}
.grid .g .delphoto{position:absolute;top:6px;right:6px;width:30px;height:30px;border-radius:9px;background:rgba(0,0,0,.55);color:#fff;border:none;font-size:14px;cursor:pointer;}

/* Document dans le fil */
.bubble.docbubble{display:flex;align-items:center;gap:9px;cursor:pointer;}
.bubble.docbubble .dic{font-size:20px;}
.bubble.docbubble .dnm{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px;}

/* Liste plans / documents (onglet Plan) */
.docrow{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 13px;margin-bottom:9px;cursor:pointer;}
.docrow .docic{font-size:24px;flex-shrink:0;}
.docrow .docmeta{flex:1;min-width:0;}
.docrow .docname{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.docrow .docsub{font-size:11.5px;color:var(--muted);margin-top:2px;}
.docrow .docgo{color:var(--muted);font-size:20px;}

/* Carte (onglet Plan) */
#planMap{z-index:0;}
.mapmsg{display:flex;height:100%;align-items:center;justify-content:center;text-align:center;color:#7a7164;font-size:13px;padding:18px;line-height:1.5;}
.leaflet-container{background:#cfc6b5;font-family:inherit;}

/* Auteur du rapport */
.report .rby{padding:7px 12px 0;font-size:11.5px;color:var(--muted);font-weight:600;}

/* Lisibilité — bouton Aa (3 niveaux) */
.ts-l #feed, .ts-l #docList, .ts-l #listScroll, .ts-l #teamScroll, .ts-l #docPlans, .ts-l #planScroll, .ts-l #pointScroll, .ts-l #assistScroll{zoom:1.12;}
.ts-xl #feed, .ts-xl #docList, .ts-xl #listScroll, .ts-xl #teamScroll, .ts-xl #docPlans, .ts-xl #planScroll, .ts-xl #pointScroll, .ts-xl #assistScroll{zoom:1.24;}

/* ===== v1.4 : numéro de chantier, avatars dans le fil, gérer chantier ===== */
.cnum{ font-family:'Archivo'; font-weight:800; font-size:10.5px; color:var(--orange); background:var(--orange-soft); padding:1px 6px; border-radius:6px; margin-right:3px; vertical-align:middle; }
.who .wav{ display:inline-block; width:20px; height:20px; border-radius:50%; background-size:cover; background-position:center; background-color:#cfc6b5; vertical-align:middle; margin-right:6px; }
.who .wav-i{ display:inline-flex; align-items:center; justify-content:center; font-family:'Archivo'; font-weight:700; font-size:9px; color:#fff; background:#8a8178; }
.sh-sub{ font-size:11.5px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; margin:14px 6px 4px; }

a.geo{ text-decoration:none; color:inherit; }

/* ===== v1.6 : attribution des personnes au chantier ===== */
.assignrow{ display:flex; align-items:center; gap:12px; padding:10px 4px; cursor:pointer; border-bottom:1px solid var(--line); }
.assignrow:last-child{ border-bottom:none; }
.assignrow .pa{ border-radius:50%; color:#fff; font-family:'Archivo'; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:13px; }
.assignrow .pn{ font-weight:600; font-size:14.5px; }
.assignrow .pr{ font-size:12px; color:var(--muted); }
.assignrow .chk{ width:26px; height:26px; border-radius:8px; border:2px solid var(--line); display:flex; align-items:center; justify-content:center; color:#fff; font-size:14px; flex-shrink:0; }
.assignrow .chk.on{ background:var(--orange); border-color:var(--orange); }

/* ===== v1.7 : statut + réponse sur un message, case équipe (grand écran) ===== */
/* badge de statut (sur sa propre ligne, largeur du contenu) */
.sbadge{ display:block; width:fit-content; font-size:10.5px; font-weight:800; letter-spacing:.02em; padding:2px 9px; border-radius:999px; margin-bottom:6px; }
.sbadge.fait{ background:rgba(47,163,107,.16); color:var(--green); }
.sbadge.urgent{ background:rgba(192,57,43,.16); color:var(--red); }
/* bordure colorée selon le statut */
.bubble.s-fait{ border:2px solid var(--green); }
.bubble.s-urgent{ border:2px solid var(--red); box-shadow:0 0 0 3px rgba(192,57,43,.10); }
/* citation du message auquel on répond, dans le fil */
.reply-q{ border-left:3px solid var(--orange); background:rgba(249,78,18,.06); border-radius:8px; padding:5px 9px; margin-bottom:6px; font-size:12.5px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.reply-q .ra{ color:var(--orange); font-weight:700; }
/* barre « réponse à… » au-dessus du composer */
.reply-bar{ display:flex; align-items:center; gap:8px; padding:8px 14px; background:var(--orange-soft); border-top:1px solid var(--line); }
.reply-bar .rbi{ font-size:14px; }
.reply-bar .rbt{ flex:1; min-width:0; font-size:13px; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.reply-bar .rbx{ border:none; background:transparent; font-size:15px; color:var(--muted); cursor:pointer; padding:2px 6px; line-height:1; }
/* case à cocher de la colonne Équipe du chantier */
#chantierTeam .chk{ width:22px; height:22px; border-radius:7px; border:2px solid var(--line); display:flex; align-items:center; justify-content:center; color:#fff; font-size:12px; flex-shrink:0; }
#chantierTeam .chk.on{ background:var(--orange); border-color:var(--orange); }

/* ===== v1.8 : présence + saut vers message d'origine ===== */
.odot{ position:absolute; right:-1px; bottom:-1px; width:11px; height:11px; border-radius:50%; background:var(--green); border:2px solid var(--card); box-shadow:0 0 0 1px rgba(0,0,0,.04); }
@keyframes flashb{ 0%,35%{ box-shadow:0 0 0 4px var(--orange); } 100%{ box-shadow:0 0 0 4px rgba(249,78,18,0); } }
.bubble.flash{ animation:flashb 1.8s ease-out; }

/* ===== v1.11 : pointage / heures ===== */
#pointScroll .plist{ background:var(--card); margin:0 14px; border-radius:16px; border:1px solid var(--line); overflow:hidden; }
#pointScroll .prow{ display:flex; align-items:center; gap:11px; padding:11px 14px; border-bottom:1px solid var(--line); }
#pointScroll .prow:last-child{ border-bottom:none; }
#pointScroll .pdot{ width:9px; height:9px; border-radius:50%; background:var(--green); flex-shrink:0; }
#pointScroll .pn{ font-weight:600; font-size:14.5px; }
#pointScroll .pr{ font-size:12.5px; color:var(--muted); }
#pointScroll .pdur{ font-family:'Archivo'; font-weight:700; font-size:14px; color:var(--text); flex-shrink:0; }
#pointScroll .pcard{ background:var(--card); margin:0 14px 10px; border-radius:16px; border:1px solid var(--line); padding:12px 14px; }
#pointScroll .pch{ display:flex; align-items:center; justify-content:space-between; margin-bottom:6px; }
#pointScroll .ptot{ font-family:'Archivo'; font-weight:800; color:var(--orange); }
#pointScroll .pses{ font-size:12.5px; color:var(--text); padding:3px 0; }
.daynav{ border:1px solid var(--line); background:#fff; border-radius:8px; width:30px; height:28px; font-size:16px; cursor:pointer; margin-left:4px; color:var(--text); }

/* ===== v1.12 : planning hebdo (affectations + tâches) ===== */
#planScroll .weeknav{ display:flex; align-items:center; justify-content:space-between; padding:12px 16px 8px; }
#planScroll .wktitle{ font-weight:700; font-size:14px; }
#planScroll .pday{ background:var(--card); margin:0 14px 10px; border-radius:16px; border:1px solid var(--line); padding:10px 14px; }
#planScroll .pday-h{ font-family:'Archivo'; font-weight:800; font-size:13.5px; margin-bottom:8px; }
#planScroll .todaytag{ display:inline-block; background:var(--orange); color:#fff; font-size:10px; font-weight:700; padding:1px 7px; border-radius:999px; margin-left:6px; }
#planScroll .paff{ display:flex; gap:8px; align-items:flex-start; padding:5px 0; }
#planScroll .pc{ font-size:12.5px; font-weight:700; color:var(--orange); flex:0 0 38%; }
#planScroll .ppl{ flex:1; display:flex; flex-wrap:wrap; gap:5px; }
#planScroll .chip{ background:var(--bg); border:1px solid var(--line); border-radius:999px; padding:2px 9px; font-size:12px; display:inline-flex; align-items:center; gap:6px; }
#planScroll .chip b{ cursor:pointer; color:var(--muted); font-weight:700; font-size:14px; line-height:1; }
#planScroll .ptask{ display:flex; align-items:center; gap:9px; padding:7px 0; }
#planScroll .ptask .tck{ width:22px; height:22px; border-radius:7px; border:2px solid var(--line); display:flex; align-items:center; justify-content:center; color:#fff; font-size:13px; flex-shrink:0; cursor:pointer; }
#planScroll .ptask.done .tck{ background:var(--green); border-color:var(--green); }
#planScroll .ptask.done .tt{ text-decoration:line-through; color:var(--muted); }
#planScroll .tt{ font-size:13.5px; font-weight:600; }
#planScroll .tc{ font-size:11.5px; color:var(--muted); }
#planScroll .tdel{ cursor:pointer; font-size:13px; opacity:.6; }
#planScroll .pempty{ color:var(--muted); font-size:13px; padding:2px 0; }
.planform{ display:flex; flex-direction:column; gap:8px; margin:6px 0 16px; }
.planform select, .planform input{ border:1px solid var(--line); border-radius:10px; padding:11px 12px; font-size:14px; font-family:inherit; background:#fff; color:var(--text); }

/* ===== v1.13 : contrôles rapport + édition tâche ===== */
.repctrl{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; padding:0 14px 12px; }
.repctrl input[type=date]{ border:1px solid var(--line); border-radius:10px; padding:9px 11px; font-size:13.5px; font-family:inherit; background:#fff; color:var(--text); }
.repbtn{ border:none; background:var(--orange); color:#fff; border-radius:10px; padding:9px 14px; font-size:13.5px; font-weight:700; cursor:pointer; }
.repbtn.alt{ background:var(--charcoal); }
#planScroll .tedit{ cursor:pointer; font-size:14px; opacity:.6; padding:0 2px; }

/* ===== v1.15 : vues planning (jour/semaine/mois/chantier) ===== */
.planseg{ display:flex; gap:6px; padding:12px 14px 4px; flex-wrap:wrap; }
.segb{ flex:1; min-width:64px; border:1px solid var(--line); background:#fff; color:var(--charcoal); border-radius:10px; padding:8px 6px; font-size:13px; font-weight:700; cursor:pointer; }
.segb.on{ background:var(--orange); color:#fff; border-color:var(--orange); }
.wktitle{ text-transform:capitalize; }
.plantoday{ text-align:center; padding:0 14px 6px; }
.plantoday button{ border:none; background:transparent; color:var(--orange); font-weight:700; font-size:13px; cursor:pointer; text-decoration:underline; }
/* vue chantier */
.pchcard{ background:#fff; border:1px solid var(--line); border-radius:14px; margin:10px 14px; overflow:hidden; }
.pchh{ background:var(--charcoal); color:#fff; font-weight:800; padding:10px 14px; font-size:14px; }
.pchday{ display:flex; gap:10px; align-items:flex-start; padding:9px 14px; border-top:1px solid var(--line); }
.pchdate{ flex:0 0 64px; font-size:12.5px; color:var(--muted); text-transform:capitalize; padding-top:3px; }
/* vue mois */
.pmgrid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; padding:8px 12px; }
.pmdow{ text-align:center; font-size:11px; font-weight:700; color:var(--muted); padding:4px 0; }
.pmcell{ position:relative; min-height:52px; border:1px solid var(--line); border-radius:9px; background:#fff; padding:4px 5px; cursor:pointer; display:flex; flex-direction:column; gap:3px; }
.pmcell.empty{ border:none; background:transparent; cursor:default; }
.pmcell.today{ border-color:var(--orange); box-shadow:0 0 0 1px var(--orange) inset; }
.pmnum{ font-size:12.5px; font-weight:700; color:var(--charcoal); }
.pmdot{ display:inline-block; min-width:16px; text-align:center; font-size:10.5px; font-weight:800; color:#fff; border-radius:8px; padding:1px 4px; line-height:1.4; }
.pmdot.a{ background:var(--orange); }
.pmdot.t{ background:#6b7280; }
.pmlegend{ text-align:center; font-size:11.5px; color:var(--muted); padding:2px 0 10px; }
.pmlegend .pmdot{ margin:0 2px; }

/* ===== v1.17 : tâches enrichies (priorité, statut, responsable) ===== */
.ptask.prio-haut{ border-left:4px solid #f59e0b; }
.ptask.prio-urg{ border-left:4px solid #dc2626; }
.ptask.prio-crit{ border-left:4px solid #7f1d1d; animation:critblink 1.1s ease-in-out infinite; }
@keyframes critblink{ 0%,100%{ background:#fff; } 50%{ background:#fde2e2; } }
.tmeta{ display:flex; gap:6px; align-items:center; flex-wrap:wrap; margin-top:4px; }
.tstat{ font-size:10.5px; font-weight:800; padding:1px 8px; border-radius:9px; color:#fff; letter-spacing:.2px; }
.tstat.s-todo{ background:#6b7280; }
.tstat.s-doing{ background:#2563eb; }
.tstat.s-waiting{ background:#f59e0b; }
.tstat.s-done{ background:#16a34a; }
.tstat.s-control{ background:#7c3aed; }
.tassign{ font-size:11px; color:var(--muted); }
.flbl{ font-size:11.5px; font-weight:700; color:var(--muted); margin:6px 0 -2px; }
.planform textarea{ border:1px solid var(--line); border-radius:10px; padding:9px 11px; font-family:inherit; font-size:14px; resize:vertical; background:#fff; color:var(--text); }
.tcreated{ font-size:11px; color:var(--muted); margin:4px 0; }

/* ===== v1.18 : tâches dans le fil (unifié avec planning) ===== */
.taskbubble{ border-left:4px solid var(--line); }
.taskbubble .tasktitle{ font-weight:600; }
.taskbubble .tdesc{ font-size:13px; color:var(--muted); margin-top:3px; white-space:pre-wrap; }
.taskbubble .tmeta{ margin-top:6px; }
.taskbubble.prio-haut{ border-left-color:#f59e0b; }
.taskbubble.prio-urg{ border-left-color:#dc2626; }
.taskbubble.prio-crit{ border-left-color:#7f1d1d; animation:critpulse 1.1s ease-in-out infinite; }
@keyframes critpulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(220,38,38,0); } 50%{ box-shadow:0 0 0 3px rgba(220,38,38,.35); } }
.ptask .tdesc{ font-size:12px; color:var(--muted); margin-top:2px; white-space:pre-wrap; }

/* ===== v1.19 : edition pointage ===== */
.pses .sedit{ cursor:pointer; opacity:.55; margin-left:6px; font-style:normal; }
.pses .sedit:hover{ opacity:1; }

/* ===== v1.20 : pieces jointes taches + cloture present ===== */
.taskatt{ display:flex; flex-wrap:wrap; gap:8px; margin:4px 0 2px; }
.taskatt .aitem{ position:relative; }
.taskatt .aitem img{ width:64px; height:64px; object-fit:cover; border-radius:9px; cursor:pointer; border:1px solid var(--line); }
.taskatt .afile{ font-size:12px; padding:9px 11px; border:1px solid var(--line); border-radius:9px; cursor:pointer; max-width:170px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; background:#fff; }
.taskatt .adel{ position:absolute; top:-6px; right:-6px; background:var(--charcoal); color:#fff; border-radius:50%; width:18px; height:18px; display:flex; align-items:center; justify-content:center; font-size:12px; cursor:pointer; font-style:normal; }
.taskatt .amini{ font-size:12px; }
.prow .pstop{ font-size:11px; color:var(--orange); font-weight:700; margin-top:2px; }

/* ===== v1.21 : miniatures des pieces jointes dans le fil ===== */
.attrow{ display:flex; flex-wrap:wrap; gap:6px; margin-top:7px; }
.attimg{ width:74px; height:74px; object-fit:cover; border-radius:9px; cursor:pointer; border:1px solid rgba(0,0,0,.10); background:#d8cfc2; }
.attfile{ display:inline-flex; align-items:center; gap:4px; font-size:12px; padding:7px 10px; border:1px solid var(--line); border-radius:9px; background:#fff; color:var(--text); text-decoration:none; max-width:210px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.attfile:active{ opacity:.7; }

/* ===== v1.22 : apercu des plans/documents ===== */
.plangrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; padding:12px; }
.plancard{ position:relative; border:1px solid var(--line); border-radius:12px; overflow:hidden; background:#fff; }
.pvwrap{ position:relative; height:140px; background:#f1ece4; cursor:pointer; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.pvwrap img{ width:100%; height:100%; object-fit:cover; }
.pvpdf iframe{ width:100%; height:100%; border:0; pointer-events:none; background:#fff; }
.pvpdf .pvover{ position:absolute; inset:0; }
.pvcad{ flex-direction:column; gap:6px; font-size:36px; color:#7c6f5e; }
.pvcad span{ font-size:11px; font-weight:800; letter-spacing:.04em; }
.plinfo{ padding:8px 10px; }
.plname{ font-size:12.5px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.plsub{ font-size:11px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.plancard .delmsg{ position:absolute; top:6px; right:6px; background:rgba(0,0,0,.55); color:#fff; border:none; border-radius:8px; padding:3px 7px; cursor:pointer; z-index:2; }
@media(min-width:1000px){ .plangrid{ grid-template-columns:repeat(3,1fr); } }

/* ===== v1.25 : Assistant IA ===== */
.ai-fab{ position:fixed; right:16px; bottom:84px; width:56px; height:56px; border-radius:50%; background:var(--orange); color:#fff; border:none; font-size:25px; box-shadow:0 6px 18px rgba(0,0,0,.28); cursor:pointer; z-index:60; display:none; align-items:center; justify-content:center; }
.ai-fab:active{ transform:scale(.94); }
#phone.logged[data-active="list"] .ai-fab,
#phone.logged[data-active="planning"] .ai-fab,
#phone.logged[data-active="equipe"] .ai-fab,
#phone.logged[data-active="pointage"] .ai-fab{ display:flex; }
#assistScroll{ padding:14px; display:flex; flex-direction:column; gap:10px; }
.abub{ max-width:86%; padding:10px 13px; border-radius:15px; font-size:14.5px; line-height:1.5; }
.abub.ai{ align-self:flex-start; background:#fff; border:1px solid var(--line); border-bottom-left-radius:5px; color:var(--text); }
.abub.me{ align-self:flex-end; background:var(--orange); color:#fff; border-bottom-right-radius:5px; }
.asugg{ display:flex; flex-direction:column; gap:8px; margin:2px 0 6px; }
.asugg button{ text-align:left; background:#fff; border:1px solid var(--line); border-radius:12px; padding:11px 13px; font-size:13.5px; cursor:pointer; color:var(--charcoal); }
.asugg button:active{ background:#f3efe8; }
#assistComposer{ display:flex; gap:8px; padding:10px 12px; border-top:1px solid var(--line); background:#fff; align-items:flex-end; }
#assistComposer textarea{ flex:1; border:1px solid var(--line); border-radius:18px; padding:10px 14px; font-family:inherit; font-size:15px; resize:none; max-height:120px; line-height:1.4; }
#assistComposer .sendbtn{ width:44px; height:44px; border-radius:50%; border:none; background:var(--orange); color:#fff; font-size:18px; cursor:pointer; flex:0 0 auto; }

/* ===== v1.26 : en-tête Assistant + micro ===== */
#assistant .rtop, #config .rtop, #trash .rtop, #media .rtop{ padding:calc(max(env(safe-area-inset-top, 0px), 34px) + 8px) 12px 12px; display:flex; align-items:center; gap:8px; flex-shrink:0; background:#fff; border-bottom:1px solid var(--line); }
#assistant .rtop button, #config .rtop button, #trash .rtop button, #media .rtop button{ background:none; border:none; color:var(--charcoal); cursor:pointer; }
#assistant .rtop .rback, #config .rtop .rback, #trash .rtop .rback, #media .rtop .rback{ font-size:30px; line-height:1; padding:0 4px; }
#assistant .rtop h2, #config .rtop h2, #trash .rtop h2, #media .rtop h2{ font-family:'Archivo'; font-weight:800; font-size:18px; color:var(--charcoal); flex:1; }
#assistant .rtop .rclear{ font-size:21px; color:var(--muted); padding:0 6px; }
#assistComposer .micbtn{ width:44px; height:44px; border-radius:50%; border:1px solid var(--line); background:#fff; font-size:18px; cursor:pointer; flex:0 0 auto; }
#assistComposer .micbtn.rec{ background:var(--red); border-color:var(--red); animation:critpulse 1s infinite; }

/* ===== v1.27 : en-tête date centrée dans Heures ===== */
#pointScroll .weeknav{ display:flex; align-items:center; padding:10px 14px 6px; gap:6px; }
#pointScroll .weeknav .daynav{ flex:0 0 auto; width:40px; height:36px; font-size:18px; margin-left:0; border-radius:9px; }
#pointScroll .weeknav .wktitle{ flex:1; text-align:center; font-weight:700; font-size:15px; text-transform:capitalize; }

/* ===== v1.28 : miniatures dans les rapports ===== */
.rthumbs{ display:flex; flex-wrap:wrap; gap:6px; margin:10px 14px 4px; }
.rthumbs img{ width:72px; height:72px; object-fit:cover; border-radius:8px; cursor:pointer; border:1px solid var(--line); background:#eee; }

/* ===== v1.29 : indicateur réseau + éléments en attente ===== */
.netbar{ position:fixed; top:0; left:0; right:0; z-index:300; display:none; align-items:center; justify-content:center; gap:6px; font-size:12.5px; font-weight:700; padding:calc(env(safe-area-inset-top,0px) + 4px) 10px 5px; }
.netbar.off{ background:#b3261e; color:#fff; }
.netbar.sync{ background:#1f6feb; color:#fff; }
.bubble.pending{ opacity:.7; }
.bubble.pending .meta{ color:inherit; opacity:.9; }

/* ===== v1.32 : pastille lu/non lu + total heures ===== */
.badge.read{ background:#2e9e5b; }
.pttotal{ margin:2px 14px 8px; padding:11px 14px; background:var(--charcoal); color:#fff; border-radius:12px; font-size:15px; display:flex; justify-content:space-between; align-items:center; }
.pttotal b{ font-size:18px; }

/* ===== v1.34 : documents joints aux rapports ===== */
.rfiles{ display:flex; flex-direction:column; gap:5px; margin:6px 14px 4px; }
.rfile{ display:block; padding:9px 12px; background:#fff; border:1px solid var(--line); border-radius:10px; font-size:13.5px; color:var(--charcoal); text-decoration:none; }
.rfile:active{ background:#f3efe8; }

/* ===== v1.35 : page Configuration (marque) ===== */
.cfgcard{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; margin-bottom:12px; }
.cfglbl{ display:block; font-size:12.5px; font-weight:700; color:var(--charcoal); margin-bottom:6px; }
.cfgin{ width:100%; border:1px solid var(--line); border-radius:10px; padding:10px 12px; font-family:inherit; font-size:15px; background:#fff; }

/* ===== v1.42 : bascule Miniatures / Liste (Photos & Plan) ===== */
.viewtog{ display:flex; gap:6px; padding:12px 14px 0; }
.viewtog button{ border:1px solid var(--line); background:#fff; color:var(--charcoal); border-radius:9px; padding:6px 12px; font-size:12.5px; font-weight:700; cursor:pointer; }
.viewtog button.on{ background:var(--orange); border-color:var(--orange); color:#fff; }
.flist{ display:flex; flex-direction:column; gap:8px; padding:12px 14px; }
.flist .fl{ display:flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--line); border-radius:12px; padding:8px; cursor:pointer; }
.flist .fl .fthumb{ width:54px; height:54px; object-fit:cover; border-radius:9px; background:#d8cfc2; flex-shrink:0; }
.flist .fl .fico{ width:46px; height:46px; border-radius:9px; background:var(--bg); display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; }
.flist .fl .fm{ flex:1; min-width:0; }
.flist .fl .ft{ font-size:13px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.flist .fl .fs{ font-size:11.5px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.flist .fl .fdel{ background:rgba(0,0,0,.06); border:none; border-radius:8px; width:34px; height:34px; cursor:pointer; flex-shrink:0; }

/* ===== v1.48 : médias dans les réponses de l'assistant ===== */
.amedia{ margin:8px 0 2px; }
.amedia img, .amedia video{ max-width:100%; border-radius:12px; display:block; }
.amedia img{ cursor:pointer; }
.amedia.embed{ position:relative; width:100%; padding-top:56.25%; border-radius:12px; overflow:hidden; background:#000; }
.amedia.embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.amedia a{ color:var(--orange); font-weight:700; text-decoration:none; }
