*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f3f6fb;color:#1f2937}.topbar{height:58px;background:#fff;border-bottom:1px solid #dbe3ef;display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:20}.topbar h1{font-size:18px;margin:0}.topbar nav{display:flex;gap:14px;align-items:center}.topbar a{color:#2563eb;text-decoration:none}.app{display:grid;grid-template-columns:330px minmax(400px,1fr) 330px;gap:14px;padding:14px;height:calc(100vh - 58px)}.app.left-collapsed{grid-template-columns:0 minmax(400px,1fr) 330px}.app.left-collapsed>.sidebar:not(.right){overflow:hidden;visibility:hidden}.map-area{position:relative}.sidebar-toggle{position:absolute;top:12px;left:12px;z-index:30;width:auto;padding:9px 12px;margin:0;border-radius:10px;box-shadow:0 4px 14px rgba(15,23,42,.18)}.sidebar{display:flex;flex-direction:column;gap:14px;min-width:0}.card{background:#fff;border:1px solid #dbe3ef;border-radius:12px;padding:16px;box-shadow:0 4px 14px rgba(15,23,42,.04)}.card h2{margin:0 0 12px;font-size:16px}label{display:block;margin:10px 0 5px;font-weight:600;font-size:13px}input,select,button{width:100%;padding:10px;border:1px solid #cfd8e3;border-radius:8px;font-size:14px}button{background:#2563eb;color:#fff;border:none;cursor:pointer;font-weight:600;margin-top:10px}button.secondary{background:#eef2f7;color:#1f2937}button.danger{background:#dc2626}.muted{color:#6b7280;font-size:13px}.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:10px;border-radius:8px;margin:10px 0}.login-body{display:grid;place-items:center;height:100vh}.login-card{width:360px;background:white;border:1px solid #dbe3ef;border-radius:14px;padding:24px;box-shadow:0 10px 30px rgba(15,23,42,.08)}.map-area{min-width:0}.map-viewport{height:100%;overflow:hidden;background:#e8edf5;border:1px solid #dbe3ef;border-radius:14px;position:relative;cursor:grab}.map-viewport.panning{cursor:grabbing}.map-canvas{position:absolute;left:0;top:0;transform-origin:0 0}.map-canvas img{display:block;max-width:none;user-select:none;-webkit-user-drag:none}.placeholder{padding:50px;text-align:center;color:#6b7280}.marker{position:absolute;width:36px;height:36px;transform:translate(-50%,-50%);border-radius:50%;display:grid;place-items:center;background:#2563eb;border:3px solid #fff;box-shadow:0 2px 10px rgba(0,0,0,.35);cursor:pointer;z-index:5}.marker img{width:26px;height:26px;object-fit:contain;pointer-events:none}.marker.status-active{outline:4px solid #22c55e}.marker.status-inactive{outline:4px solid #94a3b8}.marker.status-mixed{outline:4px solid #f59e0b}.marker .badge{position:absolute;right:-8px;top:-8px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#111827;color:#fff;font-size:12px;font-weight:bold;display:grid;place-items:center;border:2px solid #fff}.marker.highlight{animation:pulseMarker .75s ease-in-out 3;z-index:50}.marker.selected{box-shadow:0 0 0 5px rgba(37,99,235,.25),0 2px 10px rgba(0,0,0,.35)}@keyframes pulseMarker{0%{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 0 rgba(37,99,235,.85)}50%{transform:translate(-50%,-50%) scale(1.75);box-shadow:0 0 0 12px rgba(37,99,235,0)}100%{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 0 rgba(37,99,235,0)}}.socket-list{max-height:42vh;overflow:auto;margin-top:10px}.socket-item{padding:8px;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:7px;background:#fff;cursor:pointer}.socket-item.used{background:#f8fafc;color:#64748b}.socket-item.selected{border-color:#2563eb;background:#eff6ff}.socket-name{font-size:13px;font-weight:600}.socket-meta{font-size:12px;color:#64748b;margin-top:3px}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.chip{background:#e0ecff;color:#1d4ed8;border-radius:999px;padding:5px 8px;font-size:12px}.zoombar{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.settings-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;padding:16px}.wide{grid-column:1/-1}.preview{border:1px dashed #cfd8e3;border-radius:10px;min-height:140px;padding:10px;display:grid;place-items:center}.preview img{max-width:100%;max-height:230px}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid #e5e7eb;text-align:left}th{background:#f8fafc}.type-list{margin-top:12px;display:grid;gap:8px}.type-row{display:grid;grid-template-columns:38px 1fr auto;gap:10px;align-items:center;border:1px solid #e5e7eb;padding:8px;border-radius:8px}.type-row img{width:32px;height:32px}.socket-link{display:block;margin:6px 0;color:#2563eb;text-decoration:none}@media(max-width:1100px){.app{grid-template-columns:1fr;height:auto}.map-viewport{height:65vh}.settings-grid{grid-template-columns:1fr}}

.detail-header{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:8px}.detail-title{font-weight:700;margin:10px 0 6px}.detail-socket-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:7px 0;border-bottom:1px solid #eef2f7}.detail-socket-row .socket-link{margin:0}.small{width:auto;padding:6px 9px;font-size:12px;margin:0;border-radius:7px}.detail-socket-row .danger{background:#dc2626;color:#fff}
.detail-add-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;margin:6px 0 10px}.detail-add-row input,.detail-add-row select{margin:0}.detail-empty-add{padding:9px 0}.no-plan{background:#fff;border:1px dashed #cbd5e1;border-radius:12px;margin:30px;line-height:1.5}.map-canvas img[style*="display: none"]{width:0;height:0}

/* V18 - sélection plus visible */
.selection-banner{position:absolute;top:12px;left:68px;right:12px;z-index:30;background:#eff6ff;color:#1e3a8a;border:1px solid #93c5fd;border-radius:10px;padding:9px 12px;box-shadow:0 4px 14px rgba(15,23,42,.12);font-size:14px}.selection-banner span{color:#475569;font-size:12px;margin-left:6px}.marker.selected{border:4px solid #1d4ed8!important;box-shadow:0 0 0 7px rgba(37,99,235,.28),0 4px 16px rgba(15,23,42,.45)!important;z-index:120!important}.marker.selected .badge{background:#1d4ed8}button:disabled{opacity:.45;cursor:not-allowed}
/* V20 - calques périphériques */
.checkline{display:flex;gap:8px;align-items:center;font-weight:600;margin:8px 0}.checkline input{width:auto;margin:0}.device-marker{background:#0f766e}.device-marker .device-dot{position:absolute;right:-7px;top:-7px;width:19px;height:19px;border-radius:999px;background:#0f172a;color:#fff;font-size:11px;font-weight:bold;display:grid;place-items:center;border:2px solid #fff}.device-item .socket-meta{color:#475569}.detail-toolbar{margin:8px 0 10px;display:flex;gap:8px;flex-wrap:wrap}.detail-header strong{line-height:1.25}.device-marker.highlight{animation:pulseMarker .75s ease-in-out 3;z-index:50}.settings-grid{grid-template-columns:repeat(4,1fr)}@media(max-width:1300px){.settings-grid{grid-template-columns:1fr 1fr}}@media(max-width:800px){.settings-grid{grid-template-columns:1fr}}

/* V21 - listes rétractables NetworkSocket / Périphériques */
.collapsible-card{padding:0;overflow:hidden}.collapse-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0;padding:14px 16px;background:#fff;color:#111827;border:0;border-radius:12px;font-size:16px;font-weight:700;text-align:left;cursor:pointer}.collapse-header:hover{background:#f8fafc}.collapse-indicator{font-size:12px;font-weight:700;color:#2563eb;background:#eff6ff;border-radius:999px;padding:4px 9px}.collapse-body{padding:0 16px 16px}.collapsible-card.collapsed .collapse-body{display:none}.collapsible-card.collapsed .collapse-indicator{color:#475569;background:#eef2f7}.collapsible-card:not(.collapsed) .collapse-indicator::before{content:'Masquer';font-size:12px}.collapsible-card:not(.collapsed) .collapse-indicator{font-size:0}.collapsible-card.collapsed .collapse-indicator::before{content:'Afficher';font-size:12px}.sidebar .collapsible-card.collapsed{min-height:auto}.collapsible-card:not(.collapsed) .socket-list{max-height:42vh}


/* V23 - taille configurable des icônes + sélection renforcée */
.socket-marker{width:var(--socket-icon-size,36px);height:var(--socket-icon-size,36px)}
.device-marker{width:var(--device-icon-size,36px);height:var(--device-icon-size,36px)}
.socket-marker img{width:calc(var(--socket-icon-size,36px) * .72);height:calc(var(--socket-icon-size,36px) * .72)}
.device-marker img{width:calc(var(--device-icon-size,36px) * .72);height:calc(var(--device-icon-size,36px) * .72)}
.marker.selected-attention{animation:selectedJump .78s ease-in-out 2!important}
@keyframes selectedJump{0%{transform:translate(-50%,-50%) scale(1);filter:brightness(1)}35%{transform:translate(-50%,-50%) scale(1.95);filter:brightness(1.25)}70%{transform:translate(-50%,-50%) scale(.92);filter:brightness(1.05)}100%{transform:translate(-50%,-50%) scale(1);filter:brightness(1)}}

/* V25 - objets supprimés dans iTop conservés en rouge sur le plan */
.orphan-banner{position:absolute;top:58px;left:68px;right:12px;z-index:31;background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:10px;padding:9px 12px;box-shadow:0 4px 14px rgba(15,23,42,.12);font-size:14px;font-weight:600}
.marker.status-orphan,.marker.orphan{background:#dc2626!important;outline:5px solid #ef4444!important;border-color:#fff!important;box-shadow:0 0 0 7px rgba(220,38,38,.22),0 4px 16px rgba(15,23,42,.45)!important}
.marker.orphan img{filter:grayscale(1) brightness(1.9)}
.orphan-dot{position:absolute;left:-8px;top:-8px;width:20px;height:20px;border-radius:999px;background:#dc2626;color:#fff;font-size:13px;font-weight:900;display:grid;place-items:center;border:2px solid #fff}
.orphan-alert{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:9px 10px;margin:8px 0 10px;font-size:13px;line-height:1.35}
.orphan-row{background:#fff1f2;border:1px solid #fecaca;border-radius:8px;padding:8px;margin:6px 0}.orphan-row .socket-meta,.orphan-text{color:#991b1b!important;font-weight:600}


/* V26 - chargement propre API / plan */
.global-loader{position:absolute;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(243,246,251,.72);backdrop-filter:blur(2px);border-radius:14px}.loader-box{background:#fff;border:1px solid #dbe3ef;border-radius:14px;padding:18px 22px;box-shadow:0 12px 35px rgba(15,23,42,.18);display:flex;gap:12px;align-items:center;font-weight:700;color:#1f2937}.spinner{width:24px;height:24px;border:3px solid #dbeafe;border-top-color:#2563eb;border-radius:50%;animation:spinLoader .8s linear infinite}@keyframes spinLoader{to{transform:rotate(360deg)}}.list-loading{padding:14px;border:1px dashed #cbd5e1;border-radius:10px;background:#f8fafc;color:#64748b;text-align:center;font-size:13px;margin-top:10px}.map-canvas img#planImg{min-width:1px;min-height:1px}

/* V27 - Keep active selection banner and left-sidebar toggle visible while scrolling */
.sidebar-toggle{
  position:fixed!important;
  top:70px!important;
  left:344px!important;
  z-index:1000!important;
}
.app.left-collapsed .sidebar-toggle{
  left:14px!important;
}
.selection-banner{
  position:fixed!important;
  top:70px!important;
  left:392px!important;
  right:344px!important;
  z-index:999!important;
}
.app.left-collapsed .selection-banner{
  left:62px!important;
}
@media(max-width:1100px){
  .sidebar-toggle{
    top:70px!important;
    left:14px!important;
  }
  .selection-banner{
    top:70px!important;
    left:62px!important;
    right:14px!important;
  }
}


/* V30 - mode modification et consultation lecture seule */
.map-viewport,.map-canvas,.marker{user-select:none;-webkit-user-select:none}
.marker{-webkit-user-drag:none}
#modeBtn.mode-switch{width:100%;display:grid;grid-template-columns:minmax(0,1fr) 58px minmax(0,1fr);align-items:center;gap:8px;margin-top:10px;padding:7px;border:1px solid #cbd5e1;border-radius:999px;background:#eef2f7;color:#334155;box-shadow:inset 0 1px 2px rgba(15,23,42,.08);transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}
#modeBtn.mode-switch .mode-label{min-width:0;padding:7px 6px;border-radius:999px;font-size:12px;font-weight:800;text-align:center;white-space:nowrap;color:#475569;transition:background .18s ease,color .18s ease}
#modeBtn.mode-switch .mode-switch-track{position:relative;width:58px;height:28px;border-radius:999px;background:#cbd5e1;box-shadow:inset 0 2px 5px rgba(15,23,42,.22);transition:background .18s ease}
#modeBtn.mode-switch .mode-switch-thumb{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:999px;background:#fff;box-shadow:0 2px 6px rgba(15,23,42,.3);transition:transform .18s ease}
#modeBtn.mode-switch:not(.is-editing) .mode-label-consult{background:#fff;color:#1d4ed8}
#modeBtn.mode-switch.is-editing{background:#fff7ed;border-color:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,.22),inset 0 1px 2px rgba(15,23,42,.08)}
#modeBtn.mode-switch.is-editing .mode-switch-track{background:#f59e0b}
#modeBtn.mode-switch.is-editing .mode-switch-thumb{transform:translateX(30px)}
#modeBtn.mode-switch.is-editing .mode-label-edit{background:#fed7aa;color:#9a3412}
#modeBtn.mode-switch.is-readonly{opacity:.65;cursor:not-allowed}
body.placement-ready .map-viewport{cursor:crosshair;}
body.placement-active .map-viewport.panning{cursor:grabbing;}
body.placement-active .marker{cursor:grab;}
body.placement-active .marker:active{cursor:grabbing;}
body.placement-active .topbar::after{display:none!important;content:none!important}
body.placement-active .map-area::before{display:none!important;content:none!important}
body.placement-active .map-area::after{content:'';position:absolute;inset:-5px;z-index:35;border:4px solid #f59e0b;border-radius:18px;box-shadow:0 0 0 4px rgba(245,158,11,.2),inset 0 0 0 2px rgba(245,158,11,.18);pointer-events:none}
body:not(.placement-active) .right .edit-only{display:none;}
.right .edit-only[hidden]{display:none!important}
.placement-config[hidden],.existing-actions[hidden]{display:none!important}
.readonly-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:9px 10px;margin:8px 0;}
.readonly-note{margin-top:10px;font-style:italic;}



/* V33 - tooltip, mini-map, dark mode, PDF export, colors, history, roles */
.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0}.hover-tooltip{position:fixed;z-index:2000;max-width:310px;background:#0f172a;color:#fff;border-radius:10px;padding:10px 12px;box-shadow:0 12px 30px rgba(15,23,42,.35);font-size:13px;line-height:1.35;pointer-events:none}.hover-tooltip hr{border:0;border-top:1px solid rgba(255,255,255,.2);margin:7px 0}.mini-map{position:absolute;right:18px;bottom:18px;width:210px;height:145px;z-index:80;border:2px solid rgba(15,23,42,.35);border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 10px 28px rgba(15,23,42,.25);cursor:crosshair}.mini-map img{width:100%;height:100%;object-fit:contain;background:#f8fafc}.mini-dots{position:absolute;inset:0}.mini-dot{position:absolute;width:7px;height:7px;border-radius:999px;transform:translate(-50%,-50%);border:1px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.4)}.mini-dot.socket{background:#2563eb}.mini-dot.device{background:#0f766e}.mini-view{position:absolute;border:2px solid #ef4444;background:rgba(239,68,68,.12);border-radius:4px;box-shadow:0 0 0 1px rgba(255,255,255,.7)}.history-list{max-height:220px;overflow:auto}.history-row{padding:8px 0;border-bottom:1px solid #e5e7eb;font-size:12px}.history-row strong{font-size:13px;color:#111827}.history-row span{color:#64748b}.color-pill{display:inline-block;width:16px;height:16px;border-radius:999px;border:1px solid rgba(0,0,0,.2);vertical-align:middle;margin-right:4px}.read-only-user .edit-only,.read-only-user #modeBtn,.read-only-user #undoBtn{opacity:.65}.read-only-user #modeBtn{cursor:not-allowed}.dark-mode{background:#111827;color:#e5e7eb}.dark-mode .topbar,.dark-mode .card,.dark-mode .sidebar,.dark-mode .collapse-header,.dark-mode .loader-box{background:#1f2937;color:#e5e7eb;border-color:#374151}.dark-mode input,.dark-mode select{background:#111827;color:#e5e7eb;border-color:#4b5563}.dark-mode .socket-item,.dark-mode .type-row,.dark-mode .preview,.dark-mode .readonly-detail{background:#111827;color:#e5e7eb;border-color:#374151}.dark-mode .socket-meta,.dark-mode .muted,.dark-mode .history-row span{color:#9ca3af}.dark-mode .history-row strong{color:#f3f4f6}.dark-mode th{background:#111827}.dark-mode td,.dark-mode th{border-color:#374151}.dark-mode .selection-banner{background:#172554;color:#bfdbfe;border-color:#2563eb}.dark-mode .orphan-banner{background:#450a0a;color:#fecaca;border-color:#991b1b}.dark-mode .mini-map{background:#111827;border-color:#4b5563}.dark-mode .collapse-header:hover{background:#111827}
@media print{body{background:#fff!important}.topbar,.sidebar,.sidebar-toggle,.selection-banner,.orphan-banner,.global-loader,.mini-map,.hover-tooltip{display:none!important}.app{display:block!important;height:auto!important}.map-area{height:auto!important;padding:0!important}.map-viewport{height:auto!important;overflow:visible!important;background:#fff!important}.map-canvas{transform:none!important;position:relative!important;display:inline-block!important}#planImg{display:block!important;max-width:100%!important;height:auto!important}.marker{print-color-adjust:exact;-webkit-print-color-adjust:exact}.right{display:none!important}}

/* V35 - paramètres couleurs plus lisibles, mini-map fixe, dark mode plan */
.color-editor{display:grid;grid-template-columns:72px 1fr;gap:10px;align-items:center}
.color-editor input[type="color"]{width:72px!important;height:42px!important;padding:4px!important;border-radius:10px;cursor:pointer;background:#fff}
.color-editor input[type="text"]{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;text-transform:uppercase}
.type-row.editable{cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}
.type-row.editable:hover{background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px)}
input[readonly]{background:#f8fafc;color:#64748b}
.dark-mode input[readonly]{background:#0f172a;color:#9ca3af}
.dark-mode .color-editor input[type="color"]{background:#111827;border-color:#4b5563}

/* La mini-map reste visible pendant le scroll, en bas à gauche de la zone utile */
.mini-map{position:fixed!important;left:362px!important;right:auto!important;bottom:18px!important;z-index:1100!important}
.app.left-collapsed .mini-map{left:18px!important}
@media(max-width:1100px){.mini-map{left:18px!important;width:180px;height:125px}}

/* Mode sombre : assombrir aussi la zone autour du plan, sans modifier l'image elle-même */
.dark-mode .map-area,.dark-mode .map-viewport{background:#0b1220!important;border-color:#1f2937!important}
.dark-mode .map-canvas{background:#0b1220}
.dark-mode .global-loader{background:rgba(15,23,42,.72)}
.dark-mode .placeholder{color:#cbd5e1}

.history-link{display:block;text-decoration:none;color:inherit;border-radius:8px;padding:8px 10px;margin:2px 0}.history-link:hover{background:#eff6ff}.dark-mode .history-link:hover{background:#111827}.history-row span+span{font-size:11px}.settings-history-help{margin-top:6px}
.settings-history-search{margin:0 0 10px}
.backup-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.backup-file{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;font-size:12px}
.sidebar:not(.right){overflow:hidden;padding-right:2px;min-height:0}
.sidebar.right{overflow-y:auto;padding-right:2px;min-height:0}
.sidebar:not(.right)>section.card:not(.collapsible-card){flex:0 0 auto}
.sidebar:not(.right) .collapsible-card{flex:1 1 0;min-height:0}
.sidebar:not(.right) .collapsible-card.collapsed{flex:0 0 auto;min-height:auto}
.sidebar:not(.right) .collapsible-card:not(.collapsed){display:flex;flex-direction:column;min-height:150px}
.sidebar:not(.right) .collapsible-card:not(.collapsed) .collapse-body{display:flex;flex-direction:column;min-height:0}
.sidebar:not(.right) .collapsible-card:not(.collapsed) .socket-list{flex:1 1 auto;min-height:70px;max-height:none}
@media(max-height:760px){.sidebar:not(.right){overflow-y:auto}.sidebar:not(.right) .collapsible-card:not(.collapsed){flex:0 0 auto}.sidebar:not(.right) .collapsible-card:not(.collapsed) .socket-list{max-height:180px}}

/* V37 - contraste des listes en mode sombre */
.dark-mode .socket-item.placed,
.dark-mode .device-item.placed,
.dark-mode .socket-item.used,
.dark-mode .device-item.used{
  background:rgba(37,99,235,.22);
  border-color:#60a5fa;
  color:#e0f2fe;
}
.dark-mode .socket-item.unplaced,
.dark-mode .device-item.unplaced{
  background:#0b1220;
  border-color:#374151;
  color:#cbd5e1;
  opacity:.78;
}
.dark-mode .socket-item.orphan,
.dark-mode .device-item.orphan{
  background:rgba(220,38,38,.22);
  border-color:#f87171;
  color:#fecaca;
  opacity:1;
}
.dark-mode .socket-item.placed .socket-meta,
.dark-mode .device-item.placed .socket-meta,
.dark-mode .socket-item.used .socket-meta,
.dark-mode .device-item.used .socket-meta{color:#bfdbfe;}
.dark-mode .socket-item.unplaced .socket-meta,
.dark-mode .device-item.unplaced .socket-meta{color:#94a3b8;}
.dark-mode .socket-item.orphan .socket-meta,
.dark-mode .device-item.orphan .socket-meta{color:#fecaca;}

/* Gestion des droits utilisateurs */
.user-role-list{margin-top:12px;display:grid;gap:8px;max-height:420px;overflow:auto}
.user-role-row{display:grid;grid-template-columns:minmax(0,1fr) 190px;gap:12px;align-items:center;border:1px solid #e5e7eb;border-radius:8px;padding:10px;background:#fff}
.user-role-row strong{font-size:14px}
.user-role-row select{margin:0}
.user-origin{display:inline-block;margin-left:6px;padding:2px 7px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:11px;font-weight:700;vertical-align:middle}
.user-origin.missing{background:#fef2f2;color:#991b1b}
.dark-mode .user-role-row{background:#111827;color:#e5e7eb;border-color:#374151}
.dark-mode .user-origin{background:#172554;color:#bfdbfe}
.dark-mode .user-origin.missing{background:#450a0a;color:#fecaca}
@media(max-width:800px){.user-role-row{grid-template-columns:1fr}.user-role-row select{width:100%}}

.settings-inline-grid{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}
.settings-inline-grid button{width:auto;margin:0;white-space:nowrap}
.settings-help{margin-top:6px;line-height:1.35}
.itop-class-field{position:relative}
.itop-class-dropdown{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:120;max-height:260px;overflow:auto;background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 12px 28px rgba(15,23,42,.16);padding:4px}
.itop-class-dropdown.open{display:grid}
.itop-class-option{width:100%;margin:0;padding:9px 10px;border:0;border-radius:6px;background:#fff;color:#1f2937;text-align:left;font-weight:400;display:grid;gap:2px}
.itop-class-option:hover,.itop-class-option:focus{background:#eff6ff;color:#1e3a8a;outline:none}
.itop-class-option strong{font-size:13px}
.itop-class-option span,.itop-class-empty{font-size:12px;color:#64748b}
.itop-class-empty{padding:10px}
.itop-class-status{min-height:38px;display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid transparent;border-radius:8px;background:#f8fafc}
.itop-class-status.loading{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8;font-weight:700}
.itop-class-status.loading::before{content:"";width:16px;height:16px;border:2px solid #bfdbfe;border-top-color:#2563eb;border-radius:50%;animation:spinLoader .8s linear infinite;flex:0 0 auto}
.itop-class-status.ready{background:#f8fafc;color:#475569}
.itop-class-status.error-state{border-color:#fecaca;background:#fee2e2;color:#991b1b}
input.is-loading{border-color:#93c5fd;background:#eff6ff}
button:disabled{opacity:.65;cursor:not-allowed}
.itop-class-list{margin-top:12px;display:grid;gap:8px}
.itop-class-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #e5e7eb;border-radius:8px;padding:10px;background:#fff}
.dark-mode .itop-class-row{background:#111827;color:#e5e7eb;border-color:#374151}
.dark-mode .itop-class-dropdown{background:#111827;border-color:#374151;box-shadow:0 12px 28px rgba(0,0,0,.35)}
.dark-mode .itop-class-option{background:#111827;color:#e5e7eb}
.dark-mode .itop-class-option:hover,.dark-mode .itop-class-option:focus{background:#172554;color:#bfdbfe}
.dark-mode .itop-class-option span,.dark-mode .itop-class-empty{color:#9ca3af}
.dark-mode .itop-class-status{background:#111827;border-color:#374151;color:#9ca3af}
.dark-mode .itop-class-status.loading{background:#172554;border-color:#2563eb;color:#bfdbfe}
.dark-mode .itop-class-status.error-state{background:#450a0a;border-color:#991b1b;color:#fecaca}
@media(max-width:800px){.settings-inline-grid{grid-template-columns:1fr}.settings-inline-grid button{width:100%}}

.diagnostic-toolbar{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:10px;align-items:end}
.diagnostic-toolbar button{width:auto;margin:0;white-space:nowrap}
.diagnostic-results{margin-top:14px}
.diagnostic-loading{display:flex;gap:10px;align-items:center;padding:12px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff;color:#1d4ed8}
.diagnostic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.diagnostic-card,.diagnostic-class-row{border:1px solid #e5e7eb;border-radius:8px;padding:12px;background:#fff}
.diagnostic-card.ok,.diagnostic-class-row.ok{border-color:#bbf7d0;background:#f0fdf4}
.diagnostic-card.warning{border-color:#fde68a;background:#fffbeb}
.diagnostic-card.error,.diagnostic-class-row.error{border-color:#fecaca;background:#fef2f2}
.diagnostic-card-head{display:flex;gap:10px;align-items:center;justify-content:space-between}
.diagnostic-card-head span,.diagnostic-pill{display:inline-block;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700;background:#e0e7ff;color:#3730a3}
.diagnostic-pill.ok{background:#dcfce7;color:#166534}
.diagnostic-pill.error{background:#fee2e2;color:#991b1b}
.diagnostic-card p{margin:8px 0 0}
.diagnostic-meta{margin-top:6px;font-size:12px;color:#64748b}
.diagnostic-meta ul,.diagnostic-card ul{margin:6px 0 0;padding-left:18px}
.diagnostic-section{margin-top:14px}
.diagnostic-section h3{font-size:14px;margin:0 0 8px}
.diagnostic-class-list{display:grid;gap:8px}
.diagnostic-class-row{display:grid;grid-template-columns:minmax(0,220px) minmax(0,1fr);gap:12px}
.error-text{color:#991b1b}
.dark-mode .diagnostic-card,.dark-mode .diagnostic-class-row{background:#111827;color:#e5e7eb;border-color:#374151}
.dark-mode .diagnostic-card.ok,.dark-mode .diagnostic-class-row.ok{background:#052e16;border-color:#166534}
.dark-mode .diagnostic-card.warning{background:#422006;border-color:#92400e}
.dark-mode .diagnostic-card.error,.dark-mode .diagnostic-class-row.error{background:#450a0a;border-color:#991b1b}
.dark-mode .diagnostic-meta{color:#9ca3af}
@media(max-width:900px){.diagnostic-toolbar,.diagnostic-grid,.diagnostic-class-row{grid-template-columns:1fr}.diagnostic-toolbar button{width:100%}}

/* Recherche globale et export PDF enrichi */
.global-search-card input{margin:0}
.global-search-results{display:grid;gap:8px;margin-top:10px;max-height:280px;overflow:auto}
.global-search-results:empty{display:none}
.global-search-row{width:100%;margin:0;padding:10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#1f2937;text-align:left;display:grid;gap:4px;box-shadow:none}
.global-search-row:hover{border-color:#93c5fd;background:#eff6ff}
.global-result-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.global-result-head strong{font-size:13px;line-height:1.2}
.global-result-head span{flex:0 0 auto;border-radius:999px;padding:2px 7px;background:#eef2ff;color:#3730a3;font-size:11px;font-weight:700}
.global-result-meta{font-size:12px;color:#64748b;line-height:1.25}
.global-search-empty{padding:9px 0;color:#64748b;font-size:13px}
.dark-mode .global-search-row{background:#111827;color:#e5e7eb;border-color:#374151}
.dark-mode .global-search-row:hover{background:#172554;border-color:#2563eb}
.dark-mode .global-result-head span{background:#1e3a8a;color:#bfdbfe}
.dark-mode .global-result-meta,.dark-mode .global-search-empty{color:#9ca3af}

/* Recherche globale dans le header */
.topbar{z-index:1500}
.topbar-search{position:relative;flex:1 1 420px;max-width:620px;margin:0 16px}
.topbar-search input{height:38px;background:#f8fafc}
.topbar-search .global-search-results{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:1600;margin:0;padding:8px;background:#fff;border:1px solid #dbe3ef;border-radius:10px;box-shadow:0 16px 38px rgba(15,23,42,.18);max-height:min(420px,70vh)}
.dark-mode .topbar-search .global-search-results{background:#1f2937;border-color:#374151}

/* Onglets du volet droit */
.side-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#fff;border:1px solid #dbe3ef;border-radius:12px;padding:8px;box-shadow:0 4px 14px rgba(15,23,42,.04)}
.side-tab{margin:0;padding:9px 12px;border-radius:8px;background:#eef2f7;color:#1f2937}
.side-tab.active{background:#2563eb;color:#fff}
.side-panel,.side-panel[hidden]{display:none!important;flex-direction:column;gap:14px;min-height:0}
.side-panel.active{display:flex}
.side-panel.active:not([hidden]){display:flex!important}
.dark-mode .side-tabs{background:#1f2937;border-color:#374151}
.dark-mode .side-tab{background:#111827;color:#e5e7eb;border:1px solid #374151}
.dark-mode .side-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}
.print-summary{display:none}
@media print{
  @page{margin:10mm}
  body.print-export{background:#fff!important;color:#111827!important}
  body.print-export .print-summary{display:block!important;margin:0 0 8mm;color:#111827;font-family:Arial,Helvetica,sans-serif}
  body.print-export .print-summary-head{display:flex;justify-content:space-between;gap:12mm;align-items:flex-start;border-bottom:1px solid #cbd5e1;padding-bottom:5mm;margin-bottom:4mm}
  body.print-export .print-kicker{text-transform:uppercase;font-size:10px;font-weight:700;color:#64748b}
  body.print-export .print-summary h1{margin:1mm 0 0;font-size:22px;line-height:1.15;letter-spacing:0;color:#111827}
  body.print-export .print-date{font-size:11px;color:#475569;white-space:nowrap}
  body.print-export .print-stats{display:flex;flex-wrap:wrap;gap:5px;margin:0 0 4mm}
  body.print-export .print-stats span{border:1px solid #cbd5e1;border-radius:999px;padding:3px 8px;font-size:11px;background:#f8fafc}
  body.print-export .print-warning{border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:8px;padding:7px 9px;font-size:12px;margin-bottom:4mm}
  body.print-export .print-legends{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8mm;margin-bottom:5mm}
  body.print-export .print-legends section{break-inside:avoid}
  body.print-export .print-legends h2{margin:0 0 2mm;font-size:13px;color:#111827}
  body.print-export .print-legend-row{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:6px;align-items:center;padding:2px 0;font-size:11px}
  body.print-export .print-color{width:10px;height:10px;border-radius:999px;border:1px solid rgba(0,0,0,.25);print-color-adjust:exact;-webkit-print-color-adjust:exact}
  body.print-export .print-empty{font-size:11px;color:#64748b}
  body.print-export .map-area{height:auto!important;padding:0!important;min-width:0!important}
  body.print-export .map-viewport{height:auto!important;width:100%!important;overflow:visible!important;background:#fff!important;border:0!important;border-radius:0!important;cursor:default!important}
  body.print-export .map-canvas{position:relative!important;left:0!important;top:0!important;display:block!important;width:100%!important;transform:none!important;transform-origin:0 0!important}
  body.print-export #planImg{display:block!important;width:100%!important;max-width:100%!important;height:auto!important}
  body.print-export .marker{print-color-adjust:exact;-webkit-print-color-adjust:exact}
}

/* Parametres en onglets */
.settings-shell{padding:16px;display:grid;gap:14px}
.settings-tabs{display:flex;gap:8px;align-items:center;overflow:auto;background:#fff;border:1px solid #dbe3ef;border-radius:12px;padding:8px;box-shadow:0 4px 14px rgba(15,23,42,.04)}
.settings-tab{width:auto;margin:0;padding:9px 13px;border-radius:8px;background:#eef2f7;color:#1f2937;white-space:nowrap}
.settings-tab.active{background:#2563eb;color:#fff}
.settings-panel{display:none}
.settings-panel.active{display:block}
.settings-panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dark-mode .settings-tabs{background:#1f2937;border-color:#374151}
.dark-mode .settings-tab{background:#111827;color:#e5e7eb;border:1px solid #374151}
.dark-mode .settings-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}
@media(max-width:900px){.settings-panel-grid{grid-template-columns:1fr}.settings-tabs{border-radius:0;margin:-16px -16px 0;padding:10px 16px}}

/* V38 - densite globale plus compacte */
:root{
  --panel-width:300px;
  --topbar-height:52px;
  --app-gap:10px;
  --app-padding:10px;
}
body{font-size:13px;line-height:1.35}
.topbar{height:var(--topbar-height);padding:0 14px}
.topbar h1{font-size:16px}
.topbar nav{gap:10px;font-size:13px}
.app{grid-template-columns:var(--panel-width) minmax(360px,1fr) var(--panel-width);gap:var(--app-gap);padding:var(--app-padding);height:calc(100vh - var(--topbar-height))}
.app.left-collapsed{grid-template-columns:0 minmax(360px,1fr) var(--panel-width)}
.sidebar,.side-panel,.side-panel[hidden]{gap:10px}
.card{border-radius:8px;padding:8px}
.card h2{font-size:14px;margin:0 0 9px}
label{font-size:12px;margin:7px 0 4px}
input,select,button{font-size:13px;padding:8px 9px;border-radius:7px}
button{margin-top:8px}
.small{padding:5px 8px;font-size:11px;border-radius:6px}
.login-card{width:330px;border-radius:10px;padding:20px}
.placeholder{padding:36px}
.socket-list{margin-top:8px}
.socket-item{padding:7px;margin-bottom:6px;border-radius:7px}
.socket-name{font-size:12px}
.socket-meta{font-size:11px;margin-top:2px}
.chips{gap:5px;margin-top:8px}
.chip{padding:4px 7px;font-size:11px}
.zoombar{gap:7px}
.selection-banner{top:60px!important;left:356px!important;right:310px!important;padding:7px 10px;border-radius:8px;font-size:13px}
.selection-banner span{font-size:11px}
.sidebar-toggle{top:60px!important;left:310px!important;padding:7px 10px;border-radius:8px}
.app.left-collapsed .sidebar-toggle{left:10px!important}
.app.left-collapsed .selection-banner{left:54px!important}
.orphan-banner{top:60px;left:56px;right:10px;padding:7px 10px;border-radius:8px;font-size:13px}
.collapse-header{padding:11px 12px;border-radius:8px;font-size:14px}
.collapse-body{padding:0 12px 12px}
.collapse-indicator{padding:3px 8px;font-size:11px}
.collapsible-card:not(.collapsed) .collapse-indicator::before,
.collapsible-card.collapsed .collapse-indicator::before{font-size:11px}
.detail-header{gap:8px;margin-bottom:6px}
.detail-title{margin:8px 0 5px}
.detail-socket-row{gap:7px;padding:6px 0}
.detail-add-row{gap:7px;margin:5px 0 8px}
.readonly-detail,.orphan-alert{padding:7px 8px;margin:7px 0}
.quick-actions{gap:7px;margin:7px 0}
.hover-tooltip{max-width:280px;border-radius:8px;padding:8px 10px;font-size:12px}
.mini-map{left:328px!important;bottom:14px!important;width:190px;height:130px;border-radius:8px}
.app.left-collapsed .mini-map{left:14px!important}
.history-list{max-height:190px}
.history-row{padding:7px 0;font-size:11px}
.history-row strong{font-size:12px}
.history-link{padding:7px 8px}
.settings-shell{padding:12px;gap:10px}
.settings-grid{gap:12px;padding:12px}
.settings-panel-grid{gap:12px}
.settings-tabs{gap:6px;padding:6px;border-radius:8px}
.settings-tab{padding:7px 10px;border-radius:7px}
th,td{padding:8px}
.preview{min-height:120px;padding:8px;border-radius:8px}
.preview img{max-height:200px}
.type-list,.itop-class-list,.user-role-list{gap:6px;margin-top:9px}
.type-row{grid-template-columns:34px 1fr auto;gap:8px;padding:7px;border-radius:7px}
.type-row img{width:28px;height:28px}
.user-role-row{grid-template-columns:minmax(0,1fr) 170px;gap:9px;padding:8px;border-radius:7px}
.user-role-row strong{font-size:13px}
.user-origin{font-size:10px;padding:2px 6px}
.settings-inline-grid{gap:8px}
.itop-class-dropdown{max-height:230px;border-radius:7px}
.itop-class-option{padding:7px 8px;border-radius:6px}
.itop-class-status{min-height:32px;padding:6px 8px}
.itop-class-row{gap:8px;padding:8px;border-radius:7px}
.diagnostic-toolbar{gap:8px}
.diagnostic-results{margin-top:10px}
.diagnostic-grid,.diagnostic-class-list{gap:8px}
.diagnostic-card,.diagnostic-class-row{padding:9px;border-radius:7px}
.diagnostic-class-row{grid-template-columns:minmax(0,190px) minmax(0,1fr);gap:9px}
.topbar-search{flex-basis:390px;max-width:560px;margin:0 12px}
.topbar-search input{height:34px}
.topbar-search .global-search-results{top:calc(100% + 6px);padding:6px;border-radius:8px;max-height:min(380px,70vh)}
.global-search-results{gap:6px;margin-top:8px}
.global-search-row{padding:8px;border-radius:7px;gap:3px}
.global-result-head strong{font-size:12px}
.global-result-head span{font-size:10px;padding:2px 6px}
.global-result-meta,.global-search-empty{font-size:11px}
.side-tabs{gap:6px;padding:6px;border-radius:8px}
.side-tab{padding:7px 10px;border-radius:7px}
.loader-box{padding:14px 18px;border-radius:10px}
.spinner{width:20px;height:20px}
.list-loading{padding:10px;border-radius:8px;font-size:12px}
@media(max-width:1100px){
  .app{grid-template-columns:1fr;height:auto}
  .sidebar-toggle{top:60px!important;left:10px!important}
  .selection-banner{top:60px!important;left:54px!important;right:10px!important}
  .mini-map{left:14px!important;width:170px;height:118px}
}
@media(max-width:900px){
  .settings-tabs{margin:-12px -12px 0;padding:8px 12px}
}

/* V39 - listes de selection avec le rendu d'origine, en echelle compacte */
:root{--panel-width:330px}
.sidebar-toggle{left:340px!important}
.selection-banner{left:386px!important;right:340px!important}
.mini-map{left:358px!important}
.sidebar:not(.right) .collapsible-card{border-radius:12px}
.sidebar:not(.right) .collapse-header{padding:13px 15px;border-radius:12px;font-size:15px}
.sidebar:not(.right) .collapse-body{padding:0 15px 15px}
.sidebar:not(.right) .collapse-indicator{padding:4px 9px;font-size:12px}
.sidebar:not(.right) .collapsible-card:not(.collapsed) .collapse-indicator::before,
.sidebar:not(.right) .collapsible-card.collapsed .collapse-indicator::before{font-size:12px}
.sidebar:not(.right) .socket-list{margin-top:10px}
.sidebar:not(.right) .socket-item{padding:8px;margin-bottom:7px;border-radius:8px}
.sidebar:not(.right) .socket-name{font-size:13px}
.sidebar:not(.right) .socket-meta{font-size:12px;margin-top:3px}
@media(max-width:1100px){
  .sidebar-toggle{left:10px!important}
  .selection-banner{left:54px!important;right:10px!important}
  .mini-map{left:14px!important}
}

/* V40 - panneaux de listes moins gourmands en marge interne */
.sidebar:not(.right) .collapsible-card{border-radius:8px}
.sidebar:not(.right) .collapse-header{padding:10px 10px 9px;border-radius:8px}
.sidebar:not(.right) .collapse-body{padding:0 10px 10px}
.sidebar:not(.right) .collapse-header + .collapse-body input,
.sidebar:not(.right) .collapse-header + .collapse-body select{padding:7px 8px}
.sidebar:not(.right) .socket-item{padding:7px 8px}

/* V41 - marges minimales pour les panneaux de selection */
.sidebar:not(.right) .collapsible-card{border-radius:7px}
.sidebar:not(.right) .collapse-header{padding:8px 8px 7px}
.sidebar:not(.right) .collapse-body{padding:0 8px 8px}
.sidebar:not(.right) .collapse-header + .collapse-body input,
.sidebar:not(.right) .collapse-header + .collapse-body select{padding:6px 7px}
.sidebar:not(.right) .socket-list{margin-top:7px}
.sidebar:not(.right) .socket-item{padding:6px 7px;margin-bottom:6px;border-radius:7px}

/* V42 - selection visible en mode sombre */
.dark-mode .socket-item.selected,
.dark-mode .device-item.selected,
.dark-mode .socket-item.used.selected,
.dark-mode .device-item.used.selected,
.dark-mode .socket-item.unplaced.selected,
.dark-mode .device-item.unplaced.selected{
  background:#1d4ed8!important;
  border-color:#bfdbfe!important;
  color:#fff!important;
  box-shadow:0 0 0 2px rgba(191,219,254,.55), inset 4px 0 0 #facc15!important;
  opacity:1!important;
}
.dark-mode .socket-item.selected .socket-meta,
.dark-mode .device-item.selected .socket-meta{
  color:#dbeafe!important;
}
.dark-mode .socket-item.selected .socket-name,
.dark-mode .device-item.selected .socket-name{
  color:#fff!important;
}

/* V43 - pastilles adaptees a la taille des icones */
.socket-marker .badge{
  --socket-badge-size:clamp(14px,calc(var(--socket-icon-size,36px) * .5),34px);
  --socket-badge-font:clamp(9px,calc(var(--socket-icon-size,36px) * .28),18px);
  --socket-badge-border:clamp(1px,calc(var(--socket-icon-size,36px) * .055),3px);
  top:calc(var(--socket-badge-size) * -.4);
  right:calc(var(--socket-badge-size) * -.4);
  min-width:var(--socket-badge-size);
  height:var(--socket-badge-size);
  padding:0 calc(var(--socket-badge-size) * .25);
  border-width:var(--socket-badge-border);
  font-size:var(--socket-badge-font);
  line-height:1;
}
.device-marker .device-dot{
  --device-dot-size:clamp(14px,calc(var(--device-icon-size,36px) * .5),34px);
  --device-dot-font:clamp(9px,calc(var(--device-icon-size,36px) * .28),18px);
  --device-dot-border:clamp(1px,calc(var(--device-icon-size,36px) * .055),3px);
  top:calc(var(--device-dot-size) * -.4);
  right:calc(var(--device-dot-size) * -.4);
  width:var(--device-dot-size);
  height:var(--device-dot-size);
  border-width:var(--device-dot-border);
  font-size:var(--device-dot-font);
  line-height:1;
}
.orphan-dot{
  --orphan-dot-size:clamp(14px,calc(var(--socket-icon-size,36px) * .5),34px);
  --orphan-dot-font:clamp(9px,calc(var(--socket-icon-size,36px) * .3),19px);
  --orphan-dot-border:clamp(1px,calc(var(--socket-icon-size,36px) * .055),3px);
  top:calc(var(--orphan-dot-size) * -.4);
  left:calc(var(--orphan-dot-size) * -.4);
  width:var(--orphan-dot-size);
  height:var(--orphan-dot-size);
  border-width:var(--orphan-dot-border);
  font-size:var(--orphan-dot-font);
  line-height:1;
}

/* V44 - annuler / retablir sur la largeur de l'ancien bouton */
.history-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:8px;
  margin-top:10px;
}
.history-actions button{
  min-width:0;
  width:100%;
  margin-top:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.read-only-user #redoBtn{opacity:.65}

/* V45 - alerte connexion serveur en mode modification */
.server-connection-alert{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:2600;
  width:min(360px,calc(100vw - 28px));
  padding:14px 16px;
  border-radius:10px;
  border:2px solid #b91c1c;
  background:#fee2e2;
  color:#7f1d1d;
  box-shadow:0 16px 42px rgba(127,29,29,.32);
  font-size:13px;
  line-height:1.35;
}
.server-connection-alert strong{
  display:block;
  margin-bottom:6px;
  font-size:15px;
  color:#7f1d1d;
}
.server-connection-alert span{
  display:block;
  margin-top:3px;
}
.server-connection-alert[hidden]{display:none!important}
.dark-mode .server-connection-alert{
  background:#450a0a;
  border-color:#ef4444;
  color:#fecaca;
}
.dark-mode .server-connection-alert strong{color:#fff}
.server-connection-alert.sync-pending{
  background:#fff7ed;
  border-color:#f97316;
  color:#7c2d12;
  box-shadow:0 16px 42px rgba(194,65,12,.26);
}
.server-connection-alert.sync-pending strong{color:#7c2d12}
.server-connection-alert.syncing{border-style:dashed}
.dark-mode .server-connection-alert.sync-pending{
  background:#431407;
  border-color:#fb923c;
  color:#fed7aa;
}
.dark-mode .server-connection-alert.sync-pending strong{color:#ffedd5}
.sync-status{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:2550;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  border:1px solid #dbe3ea;
  color:#475569;
  box-shadow:0 8px 22px rgba(15,23,42,.14);
  font-size:12px;
  line-height:1;
}
.sync-status[hidden]{display:none!important}
.sync-spinner{
  width:12px;
  height:12px;
  border-radius:999px;
  border:2px solid #cbd5e1;
  border-top-color:#2563eb;
  animation:syncSpin .8s linear infinite;
}
@keyframes syncSpin{to{transform:rotate(360deg)}}
.server-connection-alert:not([hidden]) + .sync-status{bottom:138px}
.dark-mode .sync-status{
  background:rgba(15,23,42,.94);
  border-color:#334155;
  color:#cbd5e1;
}
