:root{--bg:#f5f8fc;--card:#fff;--soft:#f7fbff;--line:#dbe5f1;--line2:#c3d1e2;--txt:#203044;--muted:#65758b;--blue:#1776d2;--blue2:#0c5fae;--blueS:#e8f4ff;--green:#159063;--greenS:#e7f7f0;--orange:#d47a24;--orangeS:#fff1df;--red:#c33b3b;--redS:#fdeaea;--shadow:0 12px 30px rgba(31,48,68,.08);--r:16px}*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:Arial,Helvetica,sans-serif;color:var(--txt);font-size:14px}button,input,select,textarea{font-family:inherit}.layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.side{background:#fff;border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;overflow:auto}.brand{display:flex;gap:10px;align-items:center;padding:8px 8px 18px;border-bottom:1px solid var(--line);margin-bottom:14px}.logo{width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,var(--blue),#6fc0ff);display:grid;place-items:center;color:#fff;font-weight:900;box-shadow:0 8px 18px rgba(23,118,210,.25)}.brand b{font-size:18px}.brand small{display:block;color:var(--muted);font-size:11px}.nt{padding:12px 10px 7px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8b9bb0;font-weight:800}.nav{width:100%;border:0;background:transparent;padding:10px 11px;border-radius:10px;text-align:left;cursor:pointer;margin-bottom:3px;color:var(--txt);display:flex;gap:10px;align-items:center}.nav:hover{background:var(--soft)}.nav.active{background:var(--blueS);color:var(--blue2);font-weight:800;box-shadow:inset 3px 0 0 var(--blue)}.ico{width:22px;height:22px;border-radius:7px;background:#edf3fa;display:grid;place-items:center;color:var(--blue2);font-size:12px}.main{padding:22px;min-width:0}.top{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px;display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:18px}.top h1{margin:0;font-size:22px}.top p{margin:5px 0 0;color:var(--muted);font-size:13px}
.topClean{display:grid;grid-template-columns:minmax(220px,1fr) minmax(260px,1.35fr) auto;align-items:center}.topCenterAccount{text-align:center;font-size:16px;font-weight:900;color:var(--txt);line-height:1.25;white-space:normal}.topCenterAccount small{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:700}.topVersionPill{font-size:11px;padding:6px 9px;background:#fff;border:1px solid var(--line);color:var(--muted)}
@media(max-width:980px){.topClean{display:flex;align-items:flex-start}.topCenterAccount{text-align:left;font-size:15px;width:100%;order:2}.topClean>div:first-child{order:1}.topClean .actions{order:3;width:100%;justify-content:space-between}.topVersionPill{font-size:10px}}.pill,.tag{display:inline-flex;align-items:center;border-radius:999px;font-weight:800;white-space:nowrap}.pill{background:var(--blueS);color:var(--blue2);padding:7px 10px;font-size:12px}.tag{background:#eef3f9;color:var(--txt);padding:5px 8px;font-size:12px;margin:1px}.tag.blue{background:var(--blueS);color:var(--blue2)}.tag.green{background:var(--greenS);color:var(--green)}.tag.orange{background:var(--orangeS);color:var(--orange)}.tag.red{background:var(--redS);color:var(--red)}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px}.card h2{margin:0 0 12px;font-size:18px}.card h3{margin:0 0 10px;font-size:15px}.c3{grid-column:span 3}.c4{grid-column:span 4}.c5{grid-column:span 5}.c6{grid-column:span 6}.c7{grid-column:span 7}.c12{grid-column:span 12}.stat{display:flex;justify-content:space-between;align-items:flex-start}.stat small{display:block;color:var(--muted);margin-bottom:8px}.stat strong{font-size:27px}.badge{width:38px;height:38px;border-radius:13px;background:var(--blueS);color:var(--blue2);display:grid;place-items:center;font-weight:900}.sec{display:none}.sec.active{display:block}.form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:6px}.full{grid-column:1/-1}label{font-size:12px;font-weight:800;color:var(--muted)}input,select,textarea{border:1px solid var(--line2);border-radius:10px;padding:10px 11px;font-size:14px;color:var(--txt);outline:none;background:#fff;width:100%}textarea{min-height:92px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,118,210,.12)}.actions,.miniActions{display:flex;gap:8px;flex-wrap:wrap}.actions{margin-top:14px}.btn{border:0;border-radius:10px;padding:10px 13px;background:var(--blue);color:#fff;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(23,118,210,.18)}.btn:hover{background:var(--blue2)}.btn.gray{background:#eef3f9;color:var(--txt);border:1px solid var(--line);box-shadow:none}.btn.red{background:var(--red);box-shadow:none}.small{border:1px solid var(--line);background:#f4f7fb;border-radius:9px;padding:7px 9px;cursor:pointer;font-weight:800;font-size:12px;color:var(--txt)}.small:hover{background:var(--blueS);color:var(--blue2)}.small:disabled{opacity:.45;cursor:not-allowed}.small.red:hover{background:var(--redS);color:var(--red)}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:12px}.search{display:flex;gap:8px;flex-wrap:wrap}.search input,.search select{min-width:180px}.wrap{overflow:auto}table{width:100%;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid var(--line);padding:10px 9px;text-align:left;vertical-align:top;font-size:13px}th{background:var(--soft);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px}.empty{background:var(--soft);border:1px dashed var(--line2);border-radius:14px;padding:18px;text-align:center;color:var(--muted)}.note{color:var(--muted);font-size:12px;line-height:1.45}.info,.warn{padding:12px 13px;border-radius:13px;margin-bottom:14px;line-height:1.45}.info{background:var(--blueS);color:var(--blue2);border:1px solid #cfe8ff}.warn{background:var(--orangeS);color:#8b4d12;border:1px solid #ffd8a6}.modalBg{display:none;position:fixed;inset:0;background:rgba(25,38,54,.45);z-index:40;align-items:center;justify-content:center;padding:18px}.modalBg.active{display:flex}.modal{width:min(820px,100%);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 70px rgba(20,32,48,.25);padding:18px}.mh{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:14px}.mh h2{margin:0;font-size:19px}.x{border:0;background:#eef3f9;border-radius:10px;width:34px;height:34px;cursor:pointer;font-weight:900;color:var(--muted)}.toast{display:none;position:fixed;right:18px;bottom:18px;background:var(--txt);color:#fff;border-radius:12px;padding:12px 14px;z-index:50;max-width:360px}.toast.active{display:block}.roleGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.roleCard{border:1px solid var(--line);border-radius:16px;background:#fff;padding:16px;cursor:pointer;box-shadow:var(--shadow)}.roleCard:hover{border-color:var(--blue);background:var(--blueS)}.roleCard.active{border-color:var(--blue);background:var(--blueS);box-shadow:0 0 0 3px rgba(23,118,210,.10)}.roleCard h3{margin:0 0 8px}.roleCard p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.locked{opacity:.55;pointer-events:none}.mobile{display:none}.chatBox{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:12px;max-height:360px;overflow:auto;margin-bottom:12px}.bubble{max-width:78%;padding:10px 12px;border-radius:14px;margin:8px 0;border:1px solid var(--line);background:#fff}.bubble.me{margin-left:auto;background:var(--blueS);border-color:#cfe8ff}.bubble.other{margin-right:auto;background:#fff}.bubble small{display:block;color:var(--muted);margin-bottom:4px}.bubble p{margin:0;white-space:pre-wrap;line-height:1.4}.chatComposer textarea{min-height:90px}.msgBadge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--blue);color:#fff;font-size:11px;font-weight:900;margin-left:4px}.msgBadge.unread{background:var(--red);box-shadow:0 0 0 2px rgba(195,59,59,.12)}.unreadRow{background:linear-gradient(90deg,rgba(253,234,234,.55),rgba(255,255,255,0))}.lastMsg{display:block;margin-top:5px;color:var(--muted);font-size:12px;line-height:1.35}.lastMsg.unread{color:var(--red);font-weight:800}.bubble.unreadMsg{border-color:#f2b8b8;background:#fff8f8}.bubble.unreadMsg small:after{content:" · non lu";color:var(--red);font-weight:900}.messageStatusLine{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:8px 0 12px}@media(max-width:980px){.roleGrid{grid-template-columns:1fr}.layout{grid-template-columns:1fr}.side{position:fixed;left:0;top:0;bottom:0;width:280px;z-index:30;transform:translateX(-100%);transition:.2s}.side.open{transform:translateX(0)}.mobile{display:flex;position:sticky;top:0;z-index:25;justify-content:space-between;align-items:center;padding:12px 14px;background:#fff;border-bottom:1px solid var(--line)}.main{padding:14px}.top{align-items:flex-start;flex-direction:column}.c3,.c4,.c5,.c6,.c7,.c12{grid-column:1/-1}.form{grid-template-columns:1fr}table{min-width:850px}}

/* V23 ergonomie mobile et lisibilité */
.info,.warn{font-size:14px}.btn,.small{min-height:38px}.roleCard h3{color:var(--blue2)}.top .actions{align-items:center}.card h2{letter-spacing:-.01em}.badge{box-shadow:inset 0 0 0 1px rgba(23,118,210,.08)}
@media(max-width:700px){.main{padding:12px}.card{padding:14px;border-radius:14px}.top{padding:14px}.top .actions{width:100%;gap:6px}.top .actions .pill{font-size:11px}.actions .btn,.actions .small{flex:1 1 auto}.toolbar{align-items:stretch}.toolbar .actions,.toolbar .search{width:100%}.toolbar .actions .btn,.toolbar .actions .small{flex:1}.search input,.search select{min-width:100%;}.roleCard{padding:14px}.nav{padding:11px}.info,.warn{font-size:13px}}


/* V34 ergonomie PC : affichage plus compact et plus lisible sur écran d'ordinateur */
@media (min-width:981px){
  body{font-size:13px;}
  .layout{grid-template-columns:218px minmax(0,1fr);}
  .side{padding:14px 10px;}
  .brand{padding:6px 6px 14px;margin-bottom:10px;}
  .brand b{font-size:17px;}
  .logo{width:34px;height:34px;border-radius:11px;}
  .nt{padding:10px 8px 6px;font-size:10px;}
  .nav{padding:8px 9px;font-size:13px;gap:8px;}
  .ico{width:20px;height:20px;font-size:11px;}
  .main{padding:14px;}
  .top{padding:12px 14px;margin-bottom:12px;position:sticky;top:0;z-index:20;}
  .top h1{font-size:20px;}
  .top p{font-size:12px;}
  .grid{gap:12px;}
  .card{padding:12px;border-radius:14px;}
  .card h2{font-size:16px;margin-bottom:9px;}
  .card h3{font-size:14px;margin-bottom:8px;}
  .c5{grid-column:span 4;}
  .c7{grid-column:span 8;}
  .stat strong{font-size:23px;}
  .badge{width:34px;height:34px;border-radius:11px;}
  .form{gap:9px;}
  label{font-size:11px;}
  input,select,textarea{padding:8px 9px;font-size:13px;border-radius:9px;}
  textarea{min-height:74px;}
  .toolbar{margin-bottom:8px;}
  .actions{margin-top:10px;gap:7px;}
  .btn{padding:8px 11px;border-radius:9px;}
  .small{padding:6px 8px;min-height:32px;border-radius:8px;}
  .pill{padding:6px 9px;font-size:11px;}
  .tag{padding:4px 7px;font-size:11px;}
  .info,.warn{padding:10px 11px;margin-bottom:10px;font-size:13px;}
  .note{font-size:11px;}
  th,td{padding:7px 8px;font-size:12px;}
  th{font-size:10.5px;}
  .wrap{max-height:calc(100vh - 225px);overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff;}
  .wrap table{border-radius:0;}
  .wrap thead th{position:sticky;top:0;z-index:2;box-shadow:0 1px 0 var(--line);}
  .search input,.search select{min-width:150px;}
}
@media (min-width:981px) and (max-width:1180px){
  .layout{grid-template-columns:205px minmax(0,1fr);}
  .c5,.c7{grid-column:1/-1;}
  .top{position:static;}
  .wrap{max-height:none;}
}
@media (min-width:1500px){
  .layout{grid-template-columns:230px minmax(0,1fr);}
  .main{padding:16px 18px;}
  .wrap{max-height:calc(100vh - 235px);}
}


/* V37 : nettoyage des droits et affichages par rôle */
.advanced-control{display:none}
@media (min-width:981px){.miniActions .small{white-space:nowrap}.nav[data-advanced="true"]{border-left:2px solid var(--orangeS)}}


/* v0.46 : organisation du bandeau latéral et compte connecté */
.side{display:flex;flex-direction:column;}
.nav-section{margin-bottom:6px;}
.nav-bottom{margin-top:auto;padding-top:10px;border-top:1px solid var(--line);}
.sideAccount{margin-top:10px;padding:10px;border:1px solid var(--line);border-radius:13px;background:var(--soft);font-size:12px;color:var(--muted);line-height:1.35;}
.sideAccount b{display:block;color:var(--txt);font-size:13px;margin-bottom:4px;}
.sideAccount .sideBtns{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.sideAccount .small{min-height:30px;padding:5px 7px;font-size:11px;}
.topConnected{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--muted);padding:6px 9px;border-radius:999px;font-size:11px;font-weight:800;}
.topConnected strong{color:var(--txt);}
#roleChoiceCard.connected{display:none;}
@media(max-width:980px){.nav-bottom{margin-top:8px}.sideAccount{margin-bottom:10px}}



/* v0.63 corrigée — ergonomie smartphone */
.missionCards{display:none}
.missionCard{border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow);padding:14px;display:grid;gap:10px}
.missionCardHeader{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.missionCardTitle{font-size:16px;font-weight:900;line-height:1.25}
.missionCardSub{font-size:12px;color:var(--muted);line-height:1.4;margin-top:3px}
.missionMeta{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.missionMetaItem{border:1px solid var(--line);background:var(--soft);border-radius:12px;padding:9px}
.missionMetaItem small{display:block;color:var(--muted);font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}
.missionMetaItem strong{font-size:14px;line-height:1.25}
.missionCardPay{background:var(--greenS);border:1px solid #c9efde;border-radius:13px;padding:10px}
.missionCardActions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.missionCardActions .small,.missionCardActions .btn{width:100%;padding:11px 10px;font-size:13px}
.mobileOnlyHint{display:none}
@media(max-width:700px){
  .mobileOnlyHint{display:block}
  #missions .wrap{display:none}
  #missions .missionCards{display:grid;gap:12px}
  .missionMeta{grid-template-columns:1fr}
  .missionCardActions{grid-template-columns:1fr 1fr}
  .missionCardActions .fullAction{grid-column:1/-1}
  .top .actions{gap:8px}
  .topConnected{max-width:100%;white-space:normal}
  .modal{padding:14px;max-height:92vh}
  .chatBox{max-height:45vh}
}
@media(max-width:420px){.missionCardActions{grid-template-columns:1fr}.missionCardActions .fullAction{grid-column:auto}}



/* v0.63 corrigée — responsive global PC/mobile */
.responsiveCardsNote{display:none}
@media(max-width:700px){
  .top .actions{gap:6px}
  .topConnected{max-width:100%;white-space:normal}
  .wrap:not(.desktopOnlyWrap){overflow:visible}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable{min-width:0;width:100%;border-collapse:separate;border-spacing:0;background:transparent}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable thead{display:none}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable tbody{display:grid;gap:12px;width:100%}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable tr{display:block;width:100%;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:10px;margin:0}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.unreadRow{border-color:#f2b8b8;background:linear-gradient(180deg,#fff8f8,#fff)}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable td{display:block;width:100%;border-bottom:1px solid var(--line);padding:9px 4px;font-size:13px}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable td:last-child{border-bottom:0}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable td::before{content:attr(data-label);display:block;margin-bottom:4px;color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable td[data-label=""]::before{display:none}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .miniActions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .miniActions .small{width:100%;padding:10px 9px}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .lastMsg{grid-column:1/-1;margin-top:2px}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .tag{white-space:normal;line-height:1.25}
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .note{font-size:12px}
  .responsiveCardsNote{display:block}
}
@media(max-width:420px){
  .wrap:not(.desktopOnlyWrap) table.responsiveTable .miniActions{grid-template-columns:1fr}
}


/* v0.63 corrigée — lisibilité mission */
.missionEssentials{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.missionEssential{border:1px solid var(--line);background:var(--soft);border-radius:13px;padding:10px;min-width:0}
.missionEssential small{display:block;color:var(--muted);font-weight:900;font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.missionEssential strong{display:block;font-size:14px;line-height:1.28;color:var(--txt)}
.missionEssential .note{margin-top:3px}
.missionEssential.pay{background:var(--greenS);border-color:#c9efde}
.missionEssential.pay strong{font-size:17px;color:var(--green)}
.missionEssential.warnPay{background:var(--redS);border-color:#f3c1c1}
.missionEssential.warnPay strong{color:var(--red)}
.missionCardFocus{border-color:#c7dbef;box-shadow:0 14px 35px rgba(31,48,68,.10)}
.missionCardMainLine{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.missionTextBlock{background:#fff;border:1px solid var(--line);border-radius:13px;padding:10px;color:var(--muted);font-size:12px;line-height:1.45}
.missionDetailGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:10px 0 14px}
.missionDetailItem{border:1px solid var(--line);background:var(--soft);border-radius:13px;padding:11px}
.missionDetailItem small{display:block;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.06em;font-size:10px;margin-bottom:5px}
.missionDetailItem strong{display:block;font-size:15px;line-height:1.3}.missionDetailItem.pay{background:var(--greenS);border-color:#c9efde}.missionDetailItem.pay strong{color:var(--green);font-size:17px}
@media(max-width:900px){.missionEssentials{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.missionEssentials,.missionDetailGrid{grid-template-columns:1fr}.missionCardTitle{font-size:17px}.missionEssential strong{font-size:15px}.missionEssential.pay strong{font-size:18px}.missionCardFocus{padding:15px}.missionTextBlock{font-size:13px}}


/* v0.63 corrigée — correction ergonomie Mes demandes / Annonces reçues */
#demandes .c5,
#demandes .c7{
  grid-column:1 / -1;
}
@media (min-width:981px){
  #demandes .c5 .form{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  #demandes .c5 .field.full{
    grid-column:1 / -1;
  }
}
#demandes .wrap,
#missions .wrap,
#validatedMissionsBlock .wrap{
  overflow-x:hidden;
}
#demandes table,
#missions table,
#validatedMissionsBlock table{
  width:100%;
  min-width:0!important;
  table-layout:fixed;
}
#demandes th,
#demandes td,
#missions th,
#missions td,
#validatedMissionsBlock th,
#validatedMissionsBlock td{
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
}
#demandes .miniActions,
#missions .miniActions,
#validatedMissionsBlock .miniActions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;
  min-width:0;
}
#demandes .miniActions .small,
#missions .miniActions .small,
#validatedMissionsBlock .miniActions .small{
  width:100%;
  white-space:normal;
  line-height:1.2;
  padding-left:7px;
  padding-right:7px;
}
#demandes .lastMsg,
#missions .lastMsg,
#validatedMissionsBlock .lastMsg{
  grid-column:1 / -1;
  max-width:100%;
  white-space:normal;
  overflow-wrap:anywhere;
}
@media (min-width:701px){
  #demandes th:nth-child(1){width:17%;}
  #demandes th:nth-child(2){width:11%;}
  #demandes th:nth-child(3){width:13%;}
  #demandes th:nth-child(4){width:14%;}
  #demandes th:nth-child(5){width:13%;}
  #demandes th:nth-child(6){width:17%;}
  #demandes th:nth-child(7){width:15%;}
  #missions th:nth-child(1){width:17%;}
  #missions th:nth-child(2){width:13%;}
  #missions th:nth-child(3){width:13%;}
  #missions th:nth-child(4){width:14%;}
  #missions th:nth-child(5){width:18%;}
  #missions th:nth-child(6){width:10%;}
  #missions th:nth-child(7){width:15%;}
  #missions th:last-child,
  #missions td:last-child{
    width:20%;
    padding-right:16px;
  }
  #missions td:last-child .miniActions{
    grid-template-columns:repeat(2,minmax(92px,1fr));
    justify-content:start;
    justify-items:stretch;
    max-width:260px;
    margin-left:0;
    margin-right:auto;
  }
}
@media (max-width:980px){
  #demandes .c5 .form{
    grid-template-columns:1fr;
  }
}


/* v0.64 bêta — historique missions et exclusions */
.blacklistBox{border:1px solid var(--line);border-radius:14px;background:var(--soft);padding:12px;margin-top:10px}
.blacklistBox strong{display:block;margin-bottom:4px}
.historyPartner{display:flex;flex-direction:column;gap:3px}
.historyPartner .note{line-height:1.35}
@media(max-width:700px){.historyPartner{gap:5px}.blacklistBox{padding:10px}}


/* v0.73 bêta — petites annonces et profils simplifiés */
.legacyAvailabilityField{display:none!important}
.announcementHelp{background:var(--greenS);border:1px solid #c9efde;color:var(--green);border-radius:13px;padding:10px 11px;margin-bottom:10px;line-height:1.45}
.simpleProfileHelp{background:var(--blueS);border:1px solid #cfe8ff;color:var(--blue2);border-radius:13px;padding:10px 11px;margin-bottom:10px;line-height:1.45}
.cvBlock{white-space:pre-wrap;line-height:1.45}
@media(max-width:700px){.announcementHelp,.simpleProfileHelp{font-size:13px}}



/* v0.70 — page de connexion plus concrète */
.loginPage{align-items:stretch}
.loginHero{display:flex;justify-content:space-between;align-items:center;gap:14px;background:linear-gradient(135deg,#ffffff,#eef7ff)}
.loginHero h2{margin:0 0 5px;font-size:24px}
.loginHero p{margin:0;color:var(--muted)}
.loginCard{min-height:100%}
.accountList{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.accountItem{border:1px solid var(--line);border-radius:14px;background:var(--soft);padding:12px;display:grid;gap:8px}
.accountItem b{font-size:14px}
.accountItem .note{font-size:11px}
.accountItem.current{border-color:var(--blue);background:var(--blueS);box-shadow:0 0 0 3px rgba(23,118,210,.08)}
.accountItem .miniActions{margin-top:2px}
@media(max-width:980px){.accountList{grid-template-columns:1fr}.loginHero{align-items:flex-start;flex-direction:column}.loginHero h2{font-size:21px}}


/* v0.71 propre — page dédiée connexion / création de compte */
.adminTiny{border:0;background:transparent;color:var(--muted);font-size:11px;font-weight:800;cursor:pointer;padding:5px 7px;border-radius:8px}
.adminTiny:hover{background:var(--soft);color:var(--blue2)}
body.login-dedicated{background:linear-gradient(135deg,#eef7ff 0%,#f8fbff 48%,#edf4fb 100%)}
body.login-dedicated .mobile,body.login-dedicated .side,body.login-dedicated .top{display:none!important}
body.login-dedicated .layout{display:block;min-height:100vh}
body.login-dedicated .main{padding:0;min-height:100vh}
body.login-dedicated .sec{display:none!important}
body.login-dedicated #connexion.sec{display:block!important}
body.login-dedicated #connexion .loginPage{min-height:100vh;width:min(1080px,100%);margin:0 auto;padding:22px;align-content:center}
body.login-dedicated #connexion .loginHero{border-radius:22px;background:linear-gradient(135deg,#fff,#edf7ff);grid-column:1/-1}
body.login-dedicated #connexion .loginCard,body.login-dedicated #connexion .card{border-radius:20px}
body.login-dedicated #connexion .accountList{max-height:230px;overflow:auto}
body.login-dedicated #connexion .loginHero h2{font-size:26px}
@media(max-width:760px){body.login-dedicated #connexion .loginPage{padding:14px;align-content:start}.loginHero h2{font-size:22px}}



/* v0.73 — création complète compte + profil */
.signupComplete textarea{min-height:68px}
body.login-dedicated #connexion .signupComplete{align-items:start}
.v072Hidden{display:none!important}
.adminTiny{border:1px solid var(--line);background:#f7f9fc;color:#8b9bb0;border-radius:999px;padding:5px 8px;font-size:10px;font-weight:800;cursor:pointer;box-shadow:none}
.adminTiny:hover{background:var(--blueS);color:var(--blue2)}



/* v0.76 propre — création d’annonce épurée : données cabinet/adresse conservées en arrière-plan */
#demandes .field:has(#dCab),
#demandes .field:has(#dRue),
#demandes .field:has(#dCP),
#demandes .field:has(#dVille),
#demandes .field:has(#dStatut),
#demandes .field:has(#dHoraires),
#demandes .field:has(#dRemuPreview),
.modal .field:has(#eDRue),
.modal .field:has(#eDCP),
.modal .field:has(#eDVille),
.modal .field:has(#eDStatut),
.modal .field:has(#eDHoraires),
.modal .field:has(#eDRemuPreview){display:none!important;}
#demandes .card.c5{grid-column:span 5;}
#demandes .card.c5 .form{grid-template-columns:repeat(2,minmax(0,1fr));}
#demandes .card.c5 .field:has(#dMotif),
#demandes .card.c5 .field:has(#dDesc){grid-column:1/-1;}
@media(max-width:980px){#demandes .card.c5{grid-column:1/-1;}}



/* v0.76 propre — page connexion simplifiée */
.v076LoginActions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.v076AdminZone{margin-left:auto}
.v076SignupPanel{display:none}
.v076SignupPanel.active{display:block}
.v076BackLine{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}
body.login-dedicated #connexion .loginPage{width:min(820px,100%)}
body.login-dedicated #connexion .v076SignupPanel{grid-column:1/-1}
body.login-dedicated #connexion .loginCard{grid-column:1/-1}
@media(max-width:760px){.v076LoginActions .btn,.v076LoginActions .btn.gray{width:100%}.v076AdminZone{margin-left:0;width:100%;text-align:right}}



/* v0.79.2 — bandeau gauche épuré */
.sideAccount .accountDetail{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}
.sideAccount .logoutSideBtn{width:100%;justify-content:center;text-align:center;background:var(--redS);color:var(--red);border-color:#f3c1c1}
.sideAccount .logoutSideBtn:hover{background:var(--red);color:#fff}


/* v0.79.2 — tableau de bord rapide et cliquable */
#dashboard .dashQuickCard{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;position:relative;overflow:hidden}
#dashboard .dashQuickCard:hover{transform:translateY(-1px);border-color:var(--blue);box-shadow:0 14px 34px rgba(31,48,68,.12)}
#dashboard .dashQuickCard:active{transform:translateY(0)}
#dashboard .dashQuickCard small{font-size:12px;color:var(--muted)}
#dashboard .dashQuickCard .dashQuickHint{display:block;margin-top:5px;font-size:11px;color:var(--muted);line-height:1.25;font-weight:700}
#dashboard .dashQuickCard.hasUnread{border-color:#f2b8b8;background:linear-gradient(180deg,#fff8f8,#fff)}
#dashboard .dashQuickCard.hasUnread .badge{background:var(--redS);color:var(--red)}
#dashboard .dashQuickCard strong{line-height:1.05}
@media(max-width:700px){#dashboard .dashQuickCard{min-height:94px}#dashboard .dashQuickCard .badge{width:34px;height:34px}#dashboard .dashQuickCard small{font-size:12px}#dashboard .dashQuickCard strong{font-size:28px}}



/* v0.79.2 — messages non lus + retour tableau de bord smartphone */
.dashboardReturnBar{display:none;margin:-4px 0 12px 0}
.dashboardReturnBar.active{display:flex}
.dashboardReturnBtn{border:1px solid var(--line);background:#fff;color:var(--blue2);border-radius:12px;padding:10px 13px;font-weight:900;cursor:pointer;box-shadow:var(--shadow)}
.dashboardReturnBtn:hover{background:var(--blueS)}
.dashUnreadDetail{display:block;margin-top:3px;font-size:11px;color:var(--muted);font-weight:700;line-height:1.25}
#dashboard .dashQuickCard.hasUnread .dashUnreadDetail{color:var(--red)}
@media(max-width:700px){
  .dashboardReturnBar{position:sticky;top:56px;z-index:18;margin:0 0 10px 0}
  .dashboardReturnBar.active{display:flex}
  .dashboardReturnBtn{width:100%;padding:12px 13px;font-size:14px;text-align:center}
}



/* v0.79.8.9 — tableau de bord PC avec 5 raccourcis compacts */
@media (min-width:981px){
  #dashboard > .grid{grid-template-columns:repeat(15,minmax(0,1fr));}
  #dashboard .card.stat{grid-column:span 3;min-height:86px;padding:11px 12px;}
  #dashboard .card.stat strong{font-size:24px;}
  #dashboard .card.stat .badge{width:32px;height:32px;border-radius:10px;}
  #dashboard .card.c7{grid-column:span 9;}
  #dashboard .card.c5{grid-column:span 6;}
  #dashboard .dashQuickCard .dashQuickHint,
  #dashboard .dashQuickCard .dashUnreadDetail{font-size:10.5px;line-height:1.2;}
}
@media (min-width:981px) and (max-width:1180px){
  #dashboard .card.stat{grid-column:span 3;}
  #dashboard .card.c7,#dashboard .card.c5{grid-column:1/-1;}
}


/* v0.79.8.9 — nettoyage des textes explicatifs */
#roleHelp, #missionsInfo, #dRemuPreview, #eDRemuPreview{display:none!important}
.simpleProfileHelp{display:none!important}
.cleanInfoRemoved{display:none!important}



/* Personnalisation identité visuelle Dentamigo — couleurs + logo uniquement */
:root{
  --bg:#f3fbfd;
  --card:#ffffff;
  --soft:#eaf7fa;
  --line:#d7edf2;
  --line2:#1A1A1A;
  --txt:#037691;
  --muted:#5f7f87;
  --blue:#037691;
  --blue2:#025e73;
  --blueS:#e6f5f8;
  --green:#037691;
  --greenS:#e6f5f8;
  --orange:#F26F1D;
  --orangeS:#fff0e7;
  --red:#F26F1D;
  --redS:#fff0e7;
  --shadow:0 14px 32px rgba(3,118,145,.10);
}
body{background:var(--bg);color:var(--txt);}
.side{background:#ffffff;border-right:1px solid var(--line);}
.brand{align-items:center;gap:12px;}
.brandLogo{width:54px;height:54px;border-radius:16px;object-fit:contain;display:block;box-shadow:0 10px 24px rgba(3,118,145,.16);background:#fff;}
.brand b{color:#037691;letter-spacing:.01em;}
.brand small{color:#F26F1D;font-weight:800;}
.logo{background:transparent;box-shadow:none;color:transparent;}
.nav{color:#037691;}
.nav:hover{background:#eaf7fa;color:#025e73;}
.nav.active{background:#e6f5f8;color:#025e73;box-shadow:inset 3px 0 0 #F26F1D;}
.ico{background:#eaf7fa;color:#037691;}
.nt{color:#F26F1D;}
.top,.card,.modal,.roleCard,.accountItem,.missionCard{border-color:var(--line);}
.top h1,.card h2,.card h3,.roleCard h3{color:#037691;}
.pill,.tag.blue{background:#e6f5f8;color:#037691;}
.badge{background:#e6f5f8;color:#037691;box-shadow:inset 0 0 0 1px rgba(3,118,145,.10);}
input,select,textarea{color:#037691;border-color:#1A1A1A;background:rgba(255,255,255,.50);}
input::placeholder,textarea::placeholder{color:rgba(3,118,145,.55);}
input:focus,select:focus,textarea:focus{border-color:#037691;box-shadow:0 0 0 3px rgba(3,118,145,.14);}
.btn{background:#037691;color:#fff;box-shadow:0 8px 18px rgba(3,118,145,.18);}
.btn:hover{background:#025e73;}
.btn.gray,.small{background:#ffffff;color:#037691;border-color:var(--line);}
.btn.gray:hover,.small:hover{background:#e6f5f8;color:#025e73;}
.btn.red{background:#F26F1D;color:#fff;}
.tag.orange,.warn,.announcementHelp{background:#fff0e7;color:#F26F1D;border-color:#ffd3b8;}
.tag.red,.msgBadge.unread,.sideAccount .logoutSideBtn:hover{background:#F26F1D;color:#fff;}
.info,.simpleProfileHelp,.bubble.me{background:#e6f5f8;color:#037691;border-color:#bee2ea;}
.sideAccount{background:#eaf7fa;border-color:#d7edf2;color:#5f7f87;}
.sideAccount b,.topCenterAccount strong{color:#037691;}
.loginHero,body.login-dedicated #connexion .loginHero,body.login-dedicated{background:linear-gradient(135deg,#ffffff 0%,#eaf7fa 52%,#fff0e7 100%);}
.topVersionPill{background:#fff;color:#037691;border-color:#d7edf2;}
@media (min-width:981px){.brandLogo{width:48px;height:48px;border-radius:14px;}}



/* v0.79.8.9 — espace praticien : faire une demande + 3 versions de publication */
.demandesPraticienPage .demandeHubCard{background:linear-gradient(135deg,#fff,#f7fbff);}
.demandeTypeGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:10px}
.demandeTypeCard{border:1px solid var(--line);background:#fff;border-radius:16px;padding:14px;text-align:left;cursor:pointer;display:grid;gap:7px;box-shadow:var(--shadow);color:var(--txt);transition:transform .12s ease,border-color .12s ease,background .12s ease}
.demandeTypeCard:hover{transform:translateY(-1px);border-color:var(--blue);background:var(--blueS)}
.demandeTypeCard.active{border-color:var(--blue);background:var(--blueS);box-shadow:0 0 0 3px rgba(3,118,145,.10)}
.demandeTypeCard strong{font-size:15px;color:var(--blue2)}
.demandeTypeCard small{font-size:12px;color:var(--muted);line-height:1.35}
.demandeTypeIcon{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:var(--blue);color:#fff;font-weight:900}
.demandeFormHidden{display:none!important}
.demandesListPanel{grid-column:span 7}
.demandeFormPanel{grid-column:span 5}
@media(max-width:980px){.demandeTypeGrid{grid-template-columns:1fr}.demandesListPanel,.demandeFormPanel{grid-column:1/-1}}


/* v0.80.3 — formulaires complets dans les 2 types de publication */
.demandeTabs .demandeTypeCard{min-height:118px}
.demandePublicationForm .demandeHiddenCore{display:none!important}
.demandeRemuBlock{display:none}
.demandeRemuBlock.active{display:flex}
#demandeFormPanel{align-self:start}
#demandeFormTitle{color:var(--blue2)}
@media(min-width:981px){#demandeFormPanel{grid-column:span 5}.demandesListPanel{grid-column:span 7}}



/* v0.80.3 — correctifs visuels téléphone / paysage */
@media (max-width:980px){
  #demandes .wrap:not(.desktopOnlyWrap),
  #suivi .wrap:not(.desktopOnlyWrap),
  #missions .wrap:not(.desktopOnlyWrap),
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap){
    overflow:visible;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable{
    min-width:0 !important;
    width:100%;
    table-layout:auto !important;
    border-collapse:separate;
    border-spacing:0;
    background:transparent;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable thead,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable thead,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable thead,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable thead{
    display:none;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tbody,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable tbody,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable tbody,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable tbody{
    display:grid;
    gap:12px;
    width:100%;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable tr,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable tr,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable tr{
    display:block;
    width:100%;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:var(--shadow);
    padding:12px;
    margin:0;
    overflow:hidden;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td{
    display:block;
    width:100%;
    border-bottom:1px solid var(--line);
    padding:10px 0;
    font-size:14px;
    overflow-wrap:anywhere;
    word-break:break-word;
    white-space:normal;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td:first-child,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td:first-child,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td:first-child,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td:first-child{
    padding-top:0;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td:last-child,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td:last-child,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td:last-child,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td:last-child{
    border-bottom:0;
    padding-bottom:0;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td::before,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td::before,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td::before,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td::before{
    display:block;
    content:attr(data-label);
    margin:0 0 7px;
    color:var(--muted);
    font-size:10px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.08em;
    line-height:1.2;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td[data-label=""]::before,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td[data-label=""]::before,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td[data-label=""]::before,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td[data-label=""]::before{
    display:none;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable td strong,
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable td strong,
  #missions .wrap:not(.desktopOnlyWrap) table.responsiveTable td strong,
  #validatedMissionsBlock .wrap:not(.desktopOnlyWrap) table.responsiveTable td strong{
    display:block;
    line-height:1.28;
  }
  #demandes .miniActions,
  #suivi .miniActions,
  #missions .miniActions,
  #validatedMissionsBlock .miniActions{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  #demandes .miniActions .small,
  #suivi .miniActions .small,
  #missions .miniActions .small,
  #validatedMissionsBlock .miniActions .small{
    min-height:42px;
    white-space:normal;
    line-height:1.2;
  }
}
@media (max-width:560px){
  #demandes .miniActions,
  #suivi .miniActions,
  #missions .miniActions,
  #validatedMissionsBlock .miniActions{
    grid-template-columns:1fr;
  }
}



/* v0.82 — harmonisation code couleur design Dentamigo */
:root{
  --blue:#0b7b83;
  --blue2:#075f66;
  --blueS:#e8f7f7;
  --orange:#d8733f;
  --orangeS:#fff1e8;
  --bg:#edf7f8;
  --soft:#f0fbfb;
  --line:#cfe5e7;
  --line2:#b7d4d8;
  --txt:#17313a;
  --muted:#667985;
}
body{background:linear-gradient(180deg,#f6fbfc 0%,#edf7f8 100%);color:var(--txt)}
.brand b,.mobile b,.top h1,.card h2,.card h3,#title,.topCenterAccount{color:var(--blue2)}
.brand small,.top p,#subtitle{color:var(--orange);font-weight:700}.nt{color:var(--orange);letter-spacing:.14em}.logo,.brandLogo{background:#fff!important;color:var(--blue2)!important;border:1px solid var(--line);box-shadow:0 10px 24px rgba(11,123,131,.12)!important}.logo img,.brandLogo img{object-fit:contain}
.card,.top,.sideAccount,.modal,.accountItem,.roleCard{border-color:var(--line);box-shadow:0 14px 34px rgba(11,123,131,.08)}
.card{background:linear-gradient(180deg,#fff 0%,#fbffff 100%)}.top{background:rgba(255,255,255,.94)}
.nav{color:var(--blue2)}.nav:hover{background:var(--blueS)}.nav.active{background:var(--blueS);color:var(--blue2);box-shadow:inset 4px 0 0 var(--orange);font-weight:900}.ico,.badge{background:var(--blueS);color:var(--blue2);border:1px solid var(--line)}
.pill,.tag.blue,.topVersionPill{background:var(--blueS)!important;color:var(--blue2)!important;border:1px solid var(--line)}
.btn{background:var(--blue);box-shadow:0 8px 18px rgba(11,123,131,.18)}.btn:hover{background:var(--blue2)}.btn.gray,.small{background:#fff;color:var(--blue2);border-color:var(--line)}.btn.gray:hover,.small:hover{background:var(--blueS);color:var(--blue2);border-color:var(--blue)}.btn.red,.small.red:hover{background:#f7ebe7;color:#b95024;border-color:#f0c8b8}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(11,123,131,.12)}
th{background:var(--blueS);color:#587178}td{border-bottom-color:var(--line)}.wrap{border-color:var(--line)!important}.empty{background:#fbffff;border-color:var(--line2);color:var(--muted)}
.info{background:var(--blueS);color:var(--blue2);border-color:var(--line)}.warn{background:var(--orangeS);color:#9b5122;border-color:#f4c7ad}.tag.orange{background:var(--orangeS);color:var(--orange)}.tag.green{background:#e8f7f0;color:#16805d}.msgBadge.unread{background:var(--orange);box-shadow:0 0 0 2px rgba(216,115,63,.14)}
.dashboardShortcut,.stat{transition:.16s ease;border-color:var(--line)}.dashboardShortcut:hover,.stat:hover{transform:translateY(-1px);border-color:var(--blue);box-shadow:0 16px 36px rgba(11,123,131,.14)}
.dashboardShortcut.active,.stat.active,#dashboard .card:hover{border-color:var(--blue)}
#dashboard .stat:nth-child(1),#dashboard .stat:nth-child(2),#dashboard .stat:nth-child(3),#dashboard .stat:nth-child(4),#dashboard .stat:nth-child(5){border-top:3px solid var(--orange)}
#dashboard .stat strong,.stat strong{color:var(--blue2)}
.missionCard,.wrap:not(.desktopOnlyWrap) table.responsiveTable tr{border-color:var(--line);box-shadow:0 12px 30px rgba(11,123,131,.08)}
.missionCardTitle,.missionDetailItem strong,.missionEssential strong{color:var(--blue2)}.missionCardPay,.missionEssential.pay,.missionDetailItem.pay{background:#e8f7f0;border-color:#c7eadc}.missionTextBlock,.missionMetaItem,.missionDetailItem,.missionEssential{background:#fbffff;border-color:var(--line)}
.side{background:#fff}.mobile{background:rgba(255,255,255,.96);border-bottom-color:var(--line)}.sideAccount{background:var(--blueS)}.sideAccount b{color:var(--blue2)}
.loginHero{background:linear-gradient(135deg,#fff,#e8f7f7)}.adminTiny:hover{background:var(--blueS);color:var(--blue2)}
@media(max-width:980px){.side{box-shadow:18px 0 50px rgba(11,123,131,.14)}.topCenterAccount{text-align:center;color:var(--blue2)}.mobile .pill{background:var(--blueS)!important;color:var(--blue2)!important}}



/* v0.82 — Suivi mission : différenciation métier plus intuitive */
#suivi .suiviMissionRow td:first-child{
  padding-left:30px!important;
}
#suivi .suiviMissionRow td:first-child::before{
  display:none!important;
  content:none!important;
}
#suivi .suiviMissionRow td:first-child::after{
  left:10px!important;
  top:14px!important;
  bottom:14px!important;
  width:6px!important;
  border-radius:999px!important;
}
#suivi .suiviMissionRow.assistante td:first-child::after{background:#0f7f83!important;}
#suivi .suiviMissionRow.dentiste td:first-child::after{background:#d66f2f!important;}
#suivi .suiviMissionMain{gap:7px!important;min-width:0;}
#suivi .suiviMissionMain strong{line-height:1.25;overflow-wrap:anywhere;}
#suivi .suiviMissionMeta{gap:9px!important;align-items:center;}
#suivi .suiviTypeBadge{
  padding:7px 10px!important;
  border-radius:14px!important;
  font-size:12px!important;
  gap:8px!important;
  margin-top:0!important;
  box-shadow:0 6px 14px rgba(21,99,103,.08);
}
#suivi .suiviTypeBadge .suiviTypeIcon{
  width:24px;
  height:24px;
  border-radius:9px;
  display:inline-grid;
  place-items:center;
  color:white;
  font-weight:900;
  line-height:1;
}
#suivi .suiviTypeBadge .suiviTypeText{font-weight:900;}
#suivi .suiviTypeBadge em{
  font-style:normal;
  font-size:10px;
  font-weight:900;
  padding:3px 6px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
}
#suivi .suiviTypeBadge.assistante{
  background:#e9f8f8!important;
  color:#0f676d!important;
  border-color:#a8dfe2!important;
}
#suivi .suiviTypeBadge.assistante .suiviTypeIcon{background:#0f7f83;}
#suivi .suiviTypeBadge.dentiste{
  background:#fff2e9!important;
  color:#a24b15!important;
  border-color:#ffd0b0!important;
}
#suivi .suiviTypeBadge.dentiste .suiviTypeIcon{background:#d66f2f;}
@media (min-width:981px){
  #suivi .suiviMissionRow.assistante td{background:linear-gradient(90deg,#f1fbfb 0%,#ffffff 34%)!important;}
  #suivi .suiviMissionRow.dentiste td{background:linear-gradient(90deg,#fff6ee 0%,#ffffff 34%)!important;}
}
@media (max-width:980px){
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.suiviMissionRow.assistante{
    border-color:#a8dfe2!important;
    background:linear-gradient(180deg,#f0fbfb 0%,#ffffff 72%)!important;
  }
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.suiviMissionRow.dentiste{
    border-color:#ffd0b0!important;
    background:linear-gradient(180deg,#fff4eb 0%,#ffffff 72%)!important;
  }
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable .suiviMissionRow td:first-child{
    padding-left:30px!important;
  }
  #suivi .wrap:not(.desktopOnlyWrap) table.responsiveTable .suiviMissionRow td:first-child::after{
    left:8px!important;
    top:16px!important;
    bottom:16px!important;
  }
  #suivi .suiviMissionMeta{
    display:grid!important;
    grid-template-columns:1fr;
    gap:8px!important;
  }
  #suivi .suiviTypeBadge{
    width:100%;
    justify-content:flex-start;
    font-size:12px!important;
    white-space:normal!important;
  }
}



/* v0.82 — Mes demandes : différenciation visuelle métier */
#demandes .demandeMissionRow td:first-child{
  position:relative;
  padding-left:30px!important;
}
#demandes .demandeMissionRow td:first-child::after{
  content:"";
  position:absolute;
  left:10px;
  top:14px;
  bottom:14px;
  width:6px;
  border-radius:999px;
  background:var(--line2);
}
#demandes .demandeMissionRow.assistante td:first-child::after{background:#0f7f83;}
#demandes .demandeMissionRow.dentiste td:first-child::after{background:#d66f2f;}
#demandes .demandeMissionMain{display:flex;flex-direction:column;gap:7px;min-width:0}
#demandes .demandeMissionMain strong{line-height:1.25;overflow-wrap:anywhere}
#demandes .demandeMissionMeta{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
#demandes .demandeTypeBadge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:14px;border:1px solid var(--line);
  font-size:12px;font-weight:900;box-shadow:0 6px 14px rgba(21,99,103,.08);
}
#demandes .demandeTypeBadge .demandeTypeIcon{
  width:24px;height:24px;border-radius:9px;display:inline-grid;place-items:center;
  color:#fff;font-weight:900;line-height:1;
}
#demandes .demandeTypeBadge .demandeTypeText{font-weight:900}
#demandes .demandeTypeBadge em{
  font-style:normal;font-size:10px;font-weight:900;padding:3px 6px;border-radius:999px;
  background:rgba(255,255,255,.72);
}
#demandes .demandeTypeBadge.assistante{background:#e9f8f8;color:#0f676d;border-color:#a8dfe2}
#demandes .demandeTypeBadge.assistante .demandeTypeIcon{background:#0f7f83}
#demandes .demandeTypeBadge.dentiste{background:#fff2e9;color:#a24b15;border-color:#ffd0b0}
#demandes .demandeTypeBadge.dentiste .demandeTypeIcon{background:#d66f2f}
@media (min-width:981px){
  #demandes .demandeMissionRow.assistante td{background:linear-gradient(90deg,#f1fbfb 0%,#ffffff 34%)!important}
  #demandes .demandeMissionRow.dentiste td{background:linear-gradient(90deg,#fff6ee 0%,#ffffff 34%)!important}
}
@media (max-width:980px){
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.assistante{
    border-color:#a8dfe2!important;background:linear-gradient(180deg,#f0fbfb 0%,#ffffff 72%)!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.dentiste{
    border-color:#ffd0b0!important;background:linear-gradient(180deg,#fff4eb 0%,#ffffff 72%)!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable .demandeMissionRow td:first-child{padding-left:30px!important}
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable .demandeMissionRow td:first-child::after{left:8px;top:16px;bottom:16px}
  #demandes .demandeMissionMeta{display:grid;grid-template-columns:1fr;gap:8px}
  #demandes .demandeTypeBadge{width:100%;justify-content:flex-start;white-space:normal}
}



/* v0.82 — Mes demandes : repère métier vraiment visible */
#demandes .demandeMissionRow td:first-child{
  padding-left:18px!important;
}
#demandes .demandeMissionRow td:first-child::after{display:none!important;content:none!important}
#demandes .demandeHero{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:12px;
  align-items:center;
  border-radius:16px;
  padding:12px;
  border:1px solid var(--line);
  box-shadow:0 8px 18px rgba(21,99,103,.07);
}
#demandes .demandeHeroIcon{
  width:46px;
  height:46px;
  border-radius:15px;
  display:grid;
  place-items:center;
  font-size:22px;
  line-height:1;
  font-weight:900;
  color:#fff;
}
#demandes .demandeHeroText{display:grid;gap:4px;min-width:0}
#demandes .demandeHeroType{
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}
#demandes .demandeHeroTitle{
  font-size:15px;
  font-weight:900;
  line-height:1.25;
  color:var(--txt);
  overflow-wrap:anywhere;
}
#demandes .demandeHeroSub{font-size:12px;color:var(--muted);line-height:1.35;overflow-wrap:anywhere}
#demandes .demandeMissionRow.assistante .demandeHero{
  background:linear-gradient(135deg,#e7f8f8 0%,#ffffff 78%);
  border-color:#9bdadd;
}
#demandes .demandeMissionRow.assistante .demandeHeroIcon{background:#0f7f83}
#demandes .demandeMissionRow.assistante .demandeHeroType{color:#0f676d}
#demandes .demandeMissionRow.dentiste .demandeHero{
  background:linear-gradient(135deg,#fff0e4 0%,#ffffff 78%);
  border-color:#ffc69f;
}
#demandes .demandeMissionRow.dentiste .demandeHeroIcon{background:#d66f2f}
#demandes .demandeMissionRow.dentiste .demandeHeroType{color:#a24b15}
#demandes .demandeMissionRow.assistante td{border-left:0!important}
#demandes .demandeMissionRow.dentiste td{border-left:0!important}
#demandes .demandeTypeBadge{
  box-shadow:none!important;
}
@media (min-width:981px){
  #demandes .demandeMissionRow.assistante td{background:#fbffff!important}
  #demandes .demandeMissionRow.dentiste td{background:#fffaf6!important}
}
@media (max-width:980px){
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.assistante{
    border:2px solid #9bdadd!important;
    background:#f4fcfc!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.dentiste{
    border:2px solid #ffc69f!important;
    background:#fff7f0!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable .demandeMissionRow td:first-child{
    padding-left:0!important;
    padding-top:0!important;
  }
  #demandes .demandeHero{
    grid-template-columns:auto 1fr;
    padding:13px;
    border-radius:17px;
  }
  #demandes .demandeHeroIcon{
    width:52px;
    height:52px;
    font-size:24px;
  }
  #demandes .demandeHeroType{font-size:13px;letter-spacing:.06em}
  #demandes .demandeHeroTitle{font-size:16px}
}



/* v0.82 — correction réelle Mes demandes : repère métier forcé */
#demandes .demandeHero{
  display:grid!important;
  grid-template-columns:58px minmax(0,1fr)!important;
  gap:12px!important;
  align-items:center!important;
  border-radius:18px!important;
  padding:13px 14px!important;
  border:2px solid transparent!important;
  box-shadow:0 12px 28px rgba(21,99,103,.09)!important;
  min-height:74px!important;
}
#demandes .demandeHero.assistante{
  background:linear-gradient(135deg,#e5f8f8 0%,#ffffff 78%)!important;
  border-color:#8fd4d8!important;
}
#demandes .demandeHero.dentiste{
  background:linear-gradient(135deg,#fff0e3 0%,#ffffff 78%)!important;
  border-color:#ffbf92!important;
}
#demandes .demandeHeroIcon{
  width:52px!important;height:52px!important;border-radius:18px!important;
  display:grid!important;place-items:center!important;color:#fff!important;
  font-size:26px!important;font-weight:950!important;line-height:1!important;
  box-shadow:0 10px 24px rgba(0,0,0,.10)!important;
}
#demandes .demandeHero.assistante .demandeHeroIcon{background:#0f7f83!important;}
#demandes .demandeHero.dentiste .demandeHeroIcon{background:#d66f2f!important;}
#demandes .demandeHeroType{
  display:inline-flex!important;align-items:center!important;width:max-content!important;max-width:100%!important;
  padding:5px 9px!important;border-radius:999px!important;font-size:11px!important;
  font-weight:950!important;letter-spacing:.08em!important;text-transform:uppercase!important;
  margin-bottom:5px!important;white-space:normal!important;
}
#demandes .demandeHero.assistante .demandeHeroType{background:#cff0f2!important;color:#075e64!important;}
#demandes .demandeHero.dentiste .demandeHeroType{background:#ffd8be!important;color:#8d3d0e!important;}
#demandes .demandeHeroTitle{font-weight:950!important;font-size:15px!important;line-height:1.22!important;color:#10323b!important;overflow-wrap:anywhere!important;}
#demandes .demandeHeroSub{margin-top:4px!important;color:var(--muted)!important;font-size:12px!important;line-height:1.28!important;overflow-wrap:anywhere!important;}
#demandes .demandeMissionRow.assistante{--demandeAccent:#0f7f83;}
#demandes .demandeMissionRow.dentiste{--demandeAccent:#d66f2f;}
#demandes .demandeMissionRow td:first-child{position:relative!important;padding-left:18px!important;}
#demandes .demandeMissionRow td:first-child::after{
  content:""!important;position:absolute!important;left:5px!important;top:14px!important;bottom:14px!important;
  width:6px!important;border-radius:999px!important;background:var(--demandeAccent)!important;
}
#demandes .demandeMissionRow .demandeMiniBadge{
  display:inline-flex!important;align-items:center!important;justify-content:center!important;
  border-radius:12px!important;font-size:13px!important;font-weight:950!important;
  padding:8px 10px!important;min-width:82px!important;border:1px solid transparent!important;
}
#demandes .demandeMissionRow.assistante .demandeMiniBadge{background:#e5f8f8!important;color:#075e64!important;border-color:#8fd4d8!important;}
#demandes .demandeMissionRow.dentiste .demandeMiniBadge{background:#fff0e3!important;color:#8d3d0e!important;border-color:#ffbf92!important;}
@media (max-width:980px){
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.assistante{
    border:2px solid #8fd4d8!important;background:linear-gradient(180deg,#effcfc 0%,#ffffff 68%)!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable tr.demandeMissionRow.dentiste{
    border:2px solid #ffbf92!important;background:linear-gradient(180deg,#fff5ec 0%,#ffffff 68%)!important;
  }
  #demandes .wrap:not(.desktopOnlyWrap) table.responsiveTable .demandeMissionRow td:first-child{padding-left:18px!important;}
  #demandes .demandeHero{grid-template-columns:54px minmax(0,1fr)!important;padding:12px!important;}
  #demandes .demandeHeroIcon{width:48px!important;height:48px!important;font-size:24px!important;}
  #demandes .demandeHeroTitle{font-size:16px!important;}
}



/* v0.82 — correction débordement texte Mes demandes mobile */
#demandes .demandeHeroText{
  min-width:0!important;
  width:100%!important;
  overflow:hidden!important;
}
#demandes .demandeHeroType{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:flex-start!important;
  width:100%!important;
  max-width:100%!important;
  white-space:normal!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  line-height:1.22!important;
  box-sizing:border-box!important;
}
#demandes .demandeHeroTitle,
#demandes .demandeHeroSub,
#demandes .demandeMiniBadge,
#demandes .note{
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
@media (max-width:640px){
  #demandes .demandeHero{
    grid-template-columns:52px minmax(0,1fr)!important;
    gap:10px!important;
    padding:12px!important;
  }
  #demandes .demandeHeroType{
    font-size:10px!important;
    letter-spacing:.04em!important;
    padding:6px 8px!important;
    border-radius:14px!important;
  }
  #demandes .demandeHeroTitle{font-size:15px!important;}
  #demandes .demandeHeroSub{font-size:11px!important;}
}
@media (max-width:420px){
  #demandes .demandeHero{
    grid-template-columns:1fr!important;
  }
  #demandes .demandeHeroIcon{
    width:48px!important;
    height:48px!important;
    font-size:24px!important;
  }
}



/* v0.82 — stabilisation visuelle finale, sans nouvelle fonction métier */
html,body{max-width:100%;overflow-x:hidden;}
.main,.sec,.grid,.card{min-width:0;}
#demandes .demandeHero,
#suivi .suiviTypeBadge,
#demandes .demandeTypeBadge,
#demandes .demandeMiniBadge{
  max-width:100%;box-sizing:border-box;
}
#demandes .demandeHeroText,
#suivi .suiviMissionMain,
#suivi .suiviMissionMeta{
  min-width:0;max-width:100%;
}
#demandes .demandeHeroType,
#demandes .demandeHeroTitle,
#demandes .demandeHeroSub,
#suivi .suiviTypeBadge,
#suivi .suiviMissionMain strong,
#suivi .suiviMissionMeta .note{
  overflow-wrap:anywhere;word-break:break-word;
}
@media(max-width:640px){
  .topCenterAccount{font-size:14px;line-height:1.25;}
  #demandes .demandeHero{max-width:100%;}
  #demandes .demandeHeroType{width:100%!important;max-width:100%!important;}
}


/* v0.83 — nettoyage page de connexion / version publique */
.quickTestField{display:none!important;}
body.login-dedicated #connexion .loginHero .pill{background:#eaf7fa;color:#037691;border:1px solid #d7edf2;}
.v076AdminZone{position:fixed;right:12px;bottom:10px;margin:0;opacity:.32;z-index:60;}
.v076AdminZone:hover{opacity:.85;}
.v076AdminZone .adminTiny{font-size:10px;padding:4px 7px;background:transparent;border:0;box-shadow:none;color:var(--muted);}
body.login-dedicated .v076AdminZone .adminTiny:hover{background:rgba(255,255,255,.65);color:var(--blue2);}
body.login-dedicated .loginHero p{max-width:680px;}
.adminRoleCard p{color:var(--muted);}

/* v0.84 — accès public fermé */
.loginClosedNotice{margin-top:10px;padding:10px 12px;border-radius:14px;background:#fff8ed;border:1px solid #ead7b8;color:#6b4b24;font-size:13px;line-height:1.35}
body.login-dedicated .loginClosedNotice{max-width:100%}


/* v1.34.15 — suppression définitive du bouton admin local de l’écran de connexion.
   L’administration se fait uniquement avec un vrai compte Supabase. */
.v076AdminZone, .adminTiny{display:none!important;}


/* v1.34.29 — Masquage des pastilles de version en interface utilisateur.
   Les versions restent internes au code/déploiement, mais ne doivent plus apparaître aux cabinets, assistantes ou remplaçants. */
.topVersionPill,
.version-pill,
[data-version],
#version,
.app-version,
.appVersion,
.versionBadge,
#topVersion,
.badge-version,
.mobile > .pill {
  display: none !important;
}




/* v1.34.43 — bouton retour tableau de bord discret avec contour orange */
.dashboardReturnBar{
  display:none;
  margin:10px 0 14px;
  position:relative;
  z-index:12;
}
.dashboardReturnBar.active{
  display:flex;
  align-items:center;
}
.dashboardReturnBtn{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  min-height:44px;
  padding:10px 18px;
  border:1px solid #d8ece9;
  border-left:4px solid #e25d2b;
  border-radius:16px;
  background:#ffffff;
  color:#005c63;
  font-weight:900;
  font-size:15px;
  box-shadow:0 8px 20px rgba(10,92,109,.08);
  cursor:pointer;
}
.dashboardReturnBtn:hover{
  background:#f7fbfc;
  border-color:#e25d2b;
}
.dashboardReturnBtn:active{
  transform:translateY(1px);
}
.dashboardReturnIcon{
  display:inline;
  width:auto;
  height:auto;
  background:transparent;
  color:#005c63;
  font-size:18px;
  line-height:1;
}

@media (max-width:760px){
  .dashboardReturnBar{
    margin:8px 0 12px;
  }
  .dashboardReturnBtn{
    width:100%;
    min-height:46px;
    padding:11px 16px;
    border-radius:15px;
    font-size:15px;
  }
}


/* v1.34.44 — profil utilisateur plus lisible */
.dm-profile-connected-label{
  color:#5f7880;
  font-size:.92rem;
  margin-bottom:4px;
}
.dm-profile-clean{
  display:grid;
  gap:12px;
}
.dm-profile-main{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 12px;
}
.dm-profile-main b{
  color:#004f56;
  font-size:1.02rem;
}
.dm-profile-main span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 10px;
  background:#eef8f3;
  color:#00735f;
  font-weight:800;
  font-size:.86rem;
}
.dm-profile-lines{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px 14px;
}
.dm-profile-lines div{
  border:1px solid #d8ece9;
  border-radius:14px;
  background:#fbfefe;
  padding:10px 12px;
}
.dm-profile-lines strong{
  display:block;
  color:#5f7880;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-bottom:4px;
}
.dm-profile-lines span{
  color:#004f56;
  font-weight:800;
  line-height:1.25;
}
@media (max-width:760px){
  .dm-profile-lines{
    grid-template-columns:1fr;
  }
}


/* Dentamigo v1.36.2 — Annonces reçues : colonne Actions propre */
#missions td.missionsActionsCell{
  min-width: 190px;
  width: 190px;
  padding-right: 14px;
}
#missions .missionsActionsStack{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
  width:100%;
}
#missions .missionsActionsStack .small{
  width:100%;
  min-height:38px;
  white-space:normal;
  line-height:1.2;
  text-align:center;
}
#missions .missionsLastMessage{
  margin-top:2px;
}
#missions .missionsLastMessage .lastMsg{
  display:block;
  margin-top:0;
  max-width:100%;
  white-space:normal;
  overflow-wrap:anywhere;
}
@media (max-width:980px){
  #missions td.missionsActionsCell{
    min-width:unset;
    width:auto;
  }
}


/* Navigation logo vers accueil public — uniquement comportement du lien */
.dmLogoHomeLink{
  color:inherit;
  text-decoration:none;
  cursor:pointer;
}
.dmLogoHomeLink:visited{
  color:inherit;
}
.dmLogoHomeLink:hover,
.dmLogoHomeLink:focus{
  text-decoration:none;
}
.dmMobileLogoHomeLink{
  display:inline-flex;
  align-items:center;
}
