/* ================================================================
   THEME.CSS — Styles complets Node 4 Electroconcept
   Chargé dynamiquement via loadCSS() après le rendu initial.
   Les variables CSS (:root) et les règles anti-FOUC critiques
   restent dans le <style> inline de index.html.
   ================================================================ */

/* ── Variables CSS (inchangées) ────────────── */
:root {
  --bg-deep:    #0d1117;
  --bg-main:    #161b22;
  --bg-surface: #1c2128;
  --bg-raised:  #22272e;
  --border:     #30363d;
  --accent:     #d97706;
  --accent-hi:  #f59e0b;
  --accent-glow:rgba(217,119,6,0.14);
  --text:       #e6edf3;
  --text-sec:   #8b949e;
  --text-muted: #484f58;
  --green:      #3fb950;
  --red:        #f85149;
  --blue:       #58a6ff;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--bg-deep);color:var(--text);
  font:13px/1.4 'Segoe UI',system-ui,sans-serif;
  overflow:hidden;user-select:none;
}
#taskbar{
  position:fixed;top:0;left:0;right:0;height:40px;
  background:var(--bg-main);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:4px;padding:0 10px;z-index:9000;
}
.win.hidden{display:none!important}
.win{
  position:fixed;background:var(--bg-surface);border:1px solid var(--border);
  border-radius:8px;box-shadow:0 8px 20px rgba(0,0,0,0.5);
  resize:both;overflow:auto;z-index:1000;
}
.win-bar{
  background:var(--bg-raised);padding:6px 8px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;cursor:move;
  user-select:none;border-radius:8px 8px 0 0;
}
.win-title{font-weight:600;font-size:12px;}
.win-ctrls{display:flex;gap:8px;align-items:center;}
.win-x{background:none;border:none;color:var(--text-sec);font-size:14px;cursor:pointer;padding:0 4px;}
.win-x:hover{color:var(--red);}
.win-body{padding:12px;overflow:auto;max-height:calc(100% - 38px);position:relative;}

/* Popup ancré dans la fenêtre parente (Console) */
.win-body .inline-popup {
  position: absolute;
  background: var(--bg-raised);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 12px;
  z-index: 100;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
  min-width: 200px;
}
.win-body .inline-popup .popup-close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: none;
  border: none;
  color: var(--text-sec);
  cursor: pointer;
}
.frow{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:12px;}
.frow label{width:100px;font-size:11px;color:var(--text-sec);}
select,input,button{background:var(--bg-deep);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:4px;font-size:11px;}
.btn{background:var(--bg-raised);border:1px solid var(--border);cursor:pointer;}
.btn-p{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-o{background:transparent;}
.btn-sm{padding:3px 8px;font-size:10px;}
.badge{background:var(--bg-deep);border-radius:20px;padding:2px 8px;font-size:10px;}
.b-info{color:var(--blue);}
.fsect{border:1px solid var(--border);border-radius:6px;padding:8px 10px;margin-bottom:12px;}
.fsect h4{font-size:11px;margin-bottom:8px;color:var(--accent-hi);}
.bank-btn{background:var(--bg-raised);border:1px solid var(--border);padding:2px 8px;font-size:10px;border-radius:12px;cursor:pointer;}
.bank-btn.active{background: var(--accent-glow);
  border-color: var(--accent);
  color: var(--accent-hi);}
.ch-grid{display:grid;grid-template-columns:repeat(16,1fr);gap:4px;max-height:280px;overflow-y:auto;}
.ch-cell{background:var(--bg-deep);border:1px solid var(--border);border-radius:4px;text-align:center;font-size:10px;padding:6px 2px;cursor:pointer;}
.ch-cell .ch-num{display:block;font-weight:bold;color:var(--accent-hi);}
.ch-value{font-size:9px;color:var(--text-sec);}
.rdm-list{list-style:none;max-height:240px;overflow-y:auto;}
.rdm-list li{background:var(--bg-deep);margin-bottom:4px;padding:6px 8px;border-radius:4px;font-size:11px;border-left:2px solid var(--accent);cursor:pointer;}
.tb-logo{font-weight:bold;color:var(--accent);margin-right:12px;}
#tb-right{margin-left:auto;display:flex;align-items:center;gap:12px;}
.connection-status{display:flex;align-items:center;gap:4px;}
.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--green);}
.connection-status.disconnected .status-indicator{background:var(--red);}
#link-dot.up{background:var(--green);width:6px;height:6px;border-radius:50%;display:inline-block;}

/* ── Styles infos bulles ─────────────── */
/* Tooltips persistants au survol */
[title] {
  cursor: help;
}

/* Style natif amélioré */
[title]:hover {
  position: relative;
}

/* Tooltip stylisé (optionnel, remplace le title natif) */
[data-tip-custom] {
  position: relative;
  cursor: help;
}

[data-tip-custom]:hover::after {
  content: attr(data-tip-custom);
  position: absolute;
  bottom: 100%;
  left: 0;
  z-index: 10000;
  background: var(--bg-raised);
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 11px;
  white-space: nowrap;
  color: var(--text);
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
  pointer-events: none;
}

[data-tip-custom]:hover::before {
  content: '';
  position: absolute;
  bottom: 100%;
  left: 12px;
  border: 5px solid transparent;
  border-top-color: var(--accent);
  margin-bottom: -4px;
  z-index: 10000;
  pointer-events: none;
}

/* ── Taskbar (sous-éléments) ─────────────────────────────── */
.tb-logo{
  color:var(--accent-hi);font-weight:700;font-size:13px;
  letter-spacing:.4px;padding-right:10px;
  border-right:1px solid var(--border);margin-right:4px;white-space:nowrap;
}
.tb-btn{
  background:transparent;border:1px solid transparent;
  color:var(--text-sec);padding:3px 9px;border-radius:4px;
  cursor:pointer;font-size:12px;transition:all .12s;white-space:nowrap;
}
.tb-btn:hover{border-color:var(--border);color:var(--text)}
.tb-btn.on{background:var(--accent-glow);border-color:var(--accent);color:var(--accent-hi)}
#tb-right{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-sec)}
#lang-sel{
  background:#2d333b;color:#cdd9e5;
  border:1px solid #444c56;border-radius:4px;
  padding:2px 6px;font-size:12px;cursor:pointer;
}
#link-dot{width:7px;height:7px;border-radius:50%;background:var(--text-muted)}
#link-dot.up{background:var(--green)}

/* ── Window ──────────────────────────────── */
.win{
  position:absolute;background:var(--bg-main);
  border:1px solid var(--border);border-radius:7px;
  box-shadow:0 8px 32px rgba(0,0,0,.55);
  display:flex;flex-direction:column;overflow:hidden;min-width:260px;
}
.win-bar{
  background:var(--bg-raised);border-bottom:1px solid var(--border);
  padding:6px 8px;display:flex;align-items:center;gap:6px;
  cursor:grab;flex-shrink:0;
}
.win-bar:active{cursor:grabbing}
.win-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}
.win-title{font-size:11px;font-weight:600;color:var(--text);flex:1;white-space:nowrap}
.win-ctrls{display:flex;align-items:center;gap:5px}
.win-ctrls select{
  background:var(--bg-surface);border:1px solid var(--border);
  color:var(--text);padding:2px 5px;border-radius:3px;font-size:11px;cursor:pointer;
}
.win-x{
  background:transparent;border:none;color:var(--text-muted);
  cursor:pointer;font-size:13px;line-height:1;padding:1px 4px;border-radius:3px;
}
.win-x:hover{background:var(--red);color:#fff}
.win-body{padding:10px;overflow:auto;flex:1}

/* ── Forms ───────────────────────────────── */
.frow{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.frow label{color:var(--text-sec);font-size:11px;min-width:110px;text-align:right;flex-shrink:0}
.frow input,.frow select{
  background:var(--bg-surface);border:1px solid var(--border);
  color:var(--text);padding:4px 7px;border-radius:4px;font-size:12px;flex:1;
}
.frow input:focus,.frow select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow);
}
.fsect{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:5px;padding:8px 10px;margin-bottom:8px;
}
.fsect h4{
  color:var(--accent-hi);font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;
}

/* ── Buttons ─────────────────────────────── */
.btn{padding:5px 12px;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;transition:all .12s}
.btn-p{background:var(--accent);color:#fff}
.btn-p:hover{background:var(--accent-hi)}
.btn-o{background:transparent;border:1px solid var(--border);color:var(--text-sec)}
.btn-o:hover{border-color:var(--accent);color:var(--accent-hi)}
.btn-d{background:transparent;border:1px solid var(--red);color:var(--red)}
.btn-d:hover{background:var(--red);color:#fff}
.btn-sm{padding:2px 7px;font-size:10px}

/* ── Badge ───────────────────────────────── */
.badge{display:inline-block;padding:1px 6px;border-radius:9px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.b-ok{background:rgba(63,185,80,.14);color:var(--green)}
.b-err{background:rgba(248,81,73,.14);color:var(--red)}
.b-warn{background:rgba(245,158,11,.14);color:var(--accent-hi)}
.b-info{background:rgba(88,166,255,.1);color:var(--blue)}

/* ── Tabs ────────────────────────────────── */
.tabbar{display:flex;border-bottom:1px solid var(--border);margin-bottom:10px}
.tabbtn{
  background:transparent;border:none;color:var(--text-sec);
  padding:5px 12px;cursor:pointer;font-size:11px;
  border-bottom:2px solid transparent;transition:all .12s;
}
.tabbtn:hover{color:var(--text)}
.tabbtn.on{color:var(--accent-hi);border-bottom-color:var(--accent)}
.tabpanel{display:none}
.tabpanel.on{display:block}

/* ── Monitor ─────────────────────────────── */
#monitor-canvas{
  display:block;width:100%;background:var(--bg-surface);
  border:1px solid var(--border);border-radius:4px;cursor:crosshair;
}
#monitor-hover{font-size:10px;color:var(--text-sec);text-align:right;margin-top:3px;height:14px}

/* ── Console ─────────────────────────────── */
.bank-bar{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:8px}
.bank-btn{
  background:var(--bg-surface);border:1px solid var(--border);
  color:var(--text-muted);font-size:9px;padding:2px 5px;
  border-radius:3px;cursor:pointer;
}
.bank-btn.on{background:var(--accent-glow);border-color:var(--accent);color:var(--accent-hi)}
/* Select sélecteur d'univers (monitor, console, rdm, settings) */
.univ-sel{
  background:var(--bg-surface);border:1px solid var(--accent);
  color:var(--accent-hi);font-size:10px;padding:1px 4px;
  border-radius:3px;cursor:pointer;
}
.ch-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:3px}
.ch-cell{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:3px;padding:3px 2px;cursor:pointer;
  text-align:center;position:relative;overflow:hidden;
}
.ch-cell:hover{border-color:var(--accent)}
.ch-bar{
  position:absolute;bottom:0;left:0;right:0;
  background:var(--accent);opacity:.32;transition:height .08s;
}
.ch-num{font-size:8px;color:var(--text-muted);position:relative;z-index:1}
.ch-val{font-size:11px;font-weight:600;position:relative;z-index:1;line-height:1.3}

/* ── Channel popup ───────────────────────── */
#ch-popup{
  position:fixed;background:var(--bg-raised);
  border:1px solid var(--accent);border-radius:6px;
  padding:9px;z-index:9500;display:none;
  flex-direction:column;gap:5px;
  box-shadow:0 4px 20px rgba(0,0,0,.6);
}
#ch-popup label{font-size:10px;color:var(--text-sec)}
#ch-popup input[type=range]{width:170px;accent-color:var(--accent)}
#ch-popup .ch-row{display:flex;align-items:center;gap:5px}
#ch-popup input[type=number]{
  background:var(--bg-surface);border:1px solid var(--border);
  color:var(--text);padding:3px 6px;border-radius:4px;width:55px;font-size:12px;
}

/* ── RDM Discovery ───────────────────────── */
.rdm-bar{height:4px;background:var(--bg-surface);border-radius:2px;margin:7px 0;overflow:hidden}
.rdm-fill{height:100%;background:var(--accent);width:0%;transition:width .3s}
.rdm-list{list-style:none}
.rdm-item{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:4px;padding:6px 8px;margin-bottom:3px;
  display:flex;align-items:center;gap:8px;
}
.rdm-uid{font-family:monospace;font-size:10px;color:var(--accent-hi)}
.rdm-name{flex:1;font-size:11px}

/* ── RDM Config window ───────────────────── */
#win-rdm-config .win-body{
  display:flex;gap:10px;padding:10px;
  overflow:hidden;
}
.rdm-config-col{
  flex:1;overflow-y:auto;
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:5px;padding:10px;
}
.rdm-config-col h3{
  color:var(--accent-hi);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;
  margin-bottom:10px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.rdm-param-row{
  margin-bottom:10px;padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
.rdm-param-row:last-child{border-bottom:none;margin-bottom:0}
.rdm-param-row label{
  display:block;font-size:10px;font-weight:600;
  color:var(--text-sec);margin-bottom:4px;
}
.param-value{
  background:var(--bg-raised);border:1px solid var(--border);
  border-radius:4px;padding:5px 8px;font-size:11px;color:var(--text);
}
.param-editable,.param-value-editable{
  background:var(--bg-deep);border:1px solid var(--border);
  color:var(--text);padding:5px 8px;border-radius:4px;
  font-size:11px;width:100%;box-sizing:border-box;
}
.param-editable:focus,.param-value-editable:focus{
  outline:none;border-color:var(--accent);
}
.struct-fields-container{
  background:var(--bg-raised);border:1px solid var(--border);
  border-radius:4px;padding:8px;display:flex;flex-direction:column;gap:6px;
}
.struct-field-input{
  background:var(--bg-deep);border:1px solid var(--border);
  color:var(--text);padding:4px 7px;border-radius:3px;font-size:11px;flex:1;
}
.rdm-cmd-button{
  background:var(--accent)!important;color:#fff!important;
  border:none;border-radius:4px;cursor:pointer;
  font-size:10px;padding:4px 10px;white-space:nowrap;
}
.rdm-cmd-button:hover{background:var(--accent-hi)!important}

/* ── RDM Address modal ───────────────────── */
#rdm-addr-modal{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,.6);z-index:9800;display:none;
  align-items:center;justify-content:center;
}
#rdm-addr-modal.show{display:flex}
.rdm-addr-content{
  background:var(--bg-main);border:1px solid var(--accent);
  border-radius:8px;padding:20px;min-width:300px;
  box-shadow:0 8px 32px rgba(0,0,0,.6);
}
.rdm-addr-content h3{
  color:var(--accent-hi);font-size:12px;font-weight:700;
  margin-bottom:12px;text-transform:uppercase;letter-spacing:.6px;
}

/* ── HID log ─────────────────────────────── */
#hid-log{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:4px;padding:7px;font-family:monospace;font-size:10px;
  height:190px;overflow-y:auto;color:var(--text-sec);
  user-select:text;-webkit-user-select:text;cursor:text;
  white-space:pre-wrap;word-break:break-all;
}
#hid-log::selection{background:var(--accent-hi);color:#000}

/* ── Scrollbar ───────────────────────────── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ── Connexion HID ────────────────────────── */
.connection-status{
  display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  color:var(--green);padding-left:8px;
  border-left:1px solid var(--border);transition:color .3s;
}
.status-indicator{
  width:7px;height:7px;border-radius:50%;background:var(--green);
  animation:hid-pulse 1.2s infinite;box-shadow:0 0 4px var(--green);flex-shrink:0;
}
@keyframes hid-pulse{0%,100%{opacity:1}50%{opacity:.5}}
.connection-status.disconnected,
.connection-status.disconnected .status-text{color:#f55}
.connection-status.disconnected .status-indicator{background:#f55;animation:none;box-shadow:0 0 4px #f55}
.connection-status.inactive,.connection-status.inactive .status-text{color:var(--text-muted)}
.connection-status.inactive .status-indicator{background:var(--text-muted);animation:none;box-shadow:none}
.interface-disabled button,.interface-disabled input,.interface-disabled select{
  opacity:.5;cursor:not-allowed!important;pointer-events:none;
}
.interface-disabled .win{opacity:.7}

/* ── Overlay déconnexion ─────────────────── */
.disconnection-overlay{
  display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--bg-main);border:2px solid var(--red);border-radius:10px;
  padding:32px 40px;z-index:9999;text-align:center;min-width:320px;
  box-shadow:0 8px 32px rgba(0,0,0,.6);
}
.disconnection-overlay.show{display:block}
.disconnection-overlay h2{color:var(--red);margin-bottom:12px;font-size:1.3em}
.disconnection-overlay p{color:var(--text-sec);margin-bottom:8px;font-size:.95em}
.disconnection-overlay .reconnecting{
  color:var(--accent-hi);font-weight:600;margin-top:12px;animation:hid-pulse 1.2s infinite;
}
