:root{
  --bg:#0b0b0f; --bg-soft:#121217; --card:#16161d;
  --muted:#a3a3ad; --text:#e6e6ea;
  --brand:#e50914; --brand-2:#b20710;
  --ok:#18c77c; --warn:#f5a623; --danger:#ff4d4f;
  --shadow:0 8px 30px rgba(0,0,0,.4);
  --radius:18px; --radius-sm:12px;
  --ring:0 0 0 2px rgba(229,9,20,.28);
  --header-h:64px;
}

/* === Network Endpoints === */

/* Auto layout */
#pool-endpoints{
  width:100%;
  table-layout:auto;
  border-collapse:separate;
  border-spacing:0 10px;
  background:transparent;
}
#pool-endpoints thead th{ background:transparent; white-space:nowrap }
#pool-endpoints tbody td{ border-top:none; vertical-align:middle }

/* Cards */
#pool-endpoints tbody tr{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.06);
}
#pool-endpoints tbody tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
#pool-endpoints tbody tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
#pool-endpoints tbody tr:hover{border-color:rgba(229,9,20,.35); box-shadow:0 8px 24px rgba(229,9,20,.10)}

/* Alignments = header */
#pool-endpoints th:nth-child(1), #pool-endpoints td:nth-child(1){ text-align:left }   /* Coin */
#pool-endpoints th:nth-child(2), #pool-endpoints td:nth-child(2){ text-align:left } /* Server location */
#pool-endpoints th:nth-child(3), #pool-endpoints td:nth-child(3){ text-align:left } /* Country */
#pool-endpoints th:nth-child(4), #pool-endpoints td:nth-child(4){ text-align:left }  /* Ping */
#pool-endpoints th:nth-child(5), #pool-endpoints td:nth-child(5){ text-align:center } /* Status */

/* ---- Cosmetics  ---- */
.coincell{display:flex;align-items:center;gap:8px;font-weight:600}
.region-flag, .country-flag{ text-align:center }
.region-flag .flag, .country-flag .flag{ font-size:20px; line-height:1 }
.flag{font-size:18px;line-height:1}
.ping-ms{font-weight:700; font-variant-numeric:tabular-nums}
.status-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;font-weight:700;font-size:12px}
.status-badge .dot{width:8px;height:8px;border-radius:50%}
.status-up{background:#d1e7dd;color:#0f5132}
.status-up .dot{background:#198754;box-shadow:0 0 0 4px rgba(25,135,84,.15)}
.status-down{background:#ffe5e5;color:#7a1f1f}
.status-down .dot{background:#dc3545;box-shadow:0 0 0 4px rgba(220,53,69,.15)}

img.emoji{
  width:1em;
  height:1em;
  vertical-align:-0.1em;
}
.flag img.emoji{ display:inline-block }


*{box-sizing:border-box}
html{height:100%; scroll-behavior:smooth; scroll-padding-top: calc(var(--header-h) + 12px)}
body{
  min-height:100vh; margin:0; display:flex; flex-direction:column; color:var(--text);
  background:
    radial-gradient(1200px 400px at -100px -150px, rgba(229,9,20,.12), transparent 70%),
    linear-gradient(180deg,#0b0b0f, #0c0c12);
  font:500 16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  -webkit-text-size-adjust:100%;
}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
.container{width:min(1280px,92vw);margin:0 auto}

/* Header */
header.header{
  position:sticky; top:0; z-index:100;
  backdrop-filter:saturate(180%) blur(10px);
  background:rgba(11,11,15,.8);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{display:flex; align-items:center; height:var(--header-h); gap:16px; white-space:nowrap}
.brand{display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.3px}
.brand-logo{
  width:28px; height:28px; border-radius:7px;
  display:inline-flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 6px 18px rgba(229,9,20,.35);
}
.brand-logo svg{width:18px; height:18px; display:block; fill:#fff}
.brand b{font-size:18px; display:flex; gap:2px}
.brand-pool{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.brand-flix{color:#fff}
.tagline{color:var(--muted); font-weight:600; font-size:12px}

/* Menu desktop */
.menu{margin-left:auto; display:flex; gap:6px; align-items:center}
.menu a{padding:8px 12px; border-radius:10px; color:#d8d8dd; font-weight:600}
.menu a.active,.menu a:hover{color:#fff; background:rgba(229,9,20,.12); box-shadow:var(--ring)}

/* Hamburger (hidden desktop) */
.hamburger{
  display:none; margin-left:auto; width:40px; height:40px;
  align-items:center; justify-content:center; border-radius:10px;
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.04); cursor:pointer;
}
.hamburger span{display:block; width:20px; height:2px; background:#fff; border-radius:2px; position:relative}
.hamburger span::before,.hamburger span::after{
  content:""; position:absolute; left:0; width:20px; height:2px; background:#fff; border-radius:2px
}
.hamburger span::before{top:-6px}
.hamburger span::after{top:6px}

/* Mobile drawer + overlay */
.menu-dim{
  position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; pointer-events:none; z-index:99; transition:opacity .2s ease;
}
.menu-dim.show{opacity:1; pointer-events:auto}
@media (max-width:960px){
  .nav{white-space:normal}
  .tagline{display:none}
  .hamburger{display:inline-flex}
  .menu{
    position:fixed; z-index:100; top:0; right:0; bottom:0;
    width:min(82vw,360px); padding:calc(var(--header-h) + 12px) 16px 16px;
    background:var(--bg-soft); border-left:1px solid rgba(255,255,255,.08);
    flex-direction:column; align-items:flex-start; gap:4px;
    transform:translateX(100%); transition:transform .2s ease;
  }
  .menu.open{transform:translateX(0)}
  .menu a{display:block; width:100%}
}

/* Layout */
.wrapper{flex:1 0 auto}
.main-index,.main-pool{display:none}
.content-header h1{margin:0 0 8px; font-size:22px}
.content.container-fluid{padding:0}

/* Cards */
.card{
  position:relative;
  background:linear-gradient(180deg,var(--card), #15151c);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card:hover{border-color:rgba(229,9,20,.35)}
.card-header{padding:16px 18px; border-bottom:1px solid rgba(255,255,255,.06); display:flex; justify-content:space-between; align-items:center; gap:12px}
.card-title{margin:0; font-size:16px; font-weight:800; letter-spacing:.2px}
.card-body{padding:16px 18px}

/* Hero */
.hero{
  display:flex; gap:24px; align-items:center; justify-content:space-between; margin:18px 0 0;
  padding:28px; border:1px solid rgba(255,255,255,.06); border-radius:var(--radius); box-shadow:var(--shadow);
  background:
    radial-gradient(1000px 300px at 120% -40%, rgba(229,9,20,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  position:relative; overflow:hidden;
}
.hero::before{
  content:""; position:absolute; top:-40px; left:-40px; width:200px; height:200px;
  background:radial-gradient(180px 180px at 0 0, rgba(229,9,20,.20), transparent 60%);
  pointer-events:none;
}
.hero h1{ margin:0 0 8px; font-size:28px; line-height:1.2; font-weight:900; letter-spacing:.2px; }
.hero .lead{ margin:0; color:#d6d6dc; font-size:15px; }
.hero .brandline{ font-weight:900; font-size:30px; letter-spacing:.3px; }
.hero .brandline .pool{background:linear-gradient(135deg,var(--brand),var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .brandline .flix{color:#fff}

/* CTA + badges */
.cta-row{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-top:14px}
.btn{display:inline-block; padding:12px 16px; border-radius:12px; border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; font-weight:800; letter-spacing:.2px; cursor:pointer;
  transition:transform .06s ease, box-shadow .2s ease}
.btn:hover{box-shadow:0 8px 24px rgba(229,9,20,.2)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:transparent;border-color:rgba(229,9,20,.35)}
.btn-cta{padding:14px 18px; border-radius:14px; box-shadow:0 10px 26px rgba(229,9,20,.25)}
.badge{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
  font-weight:700; font-size:12px; color:#dfe1e8
}

.stat{
  display:flex; align-items:center; gap:14px; padding:14px 16px; border-radius:14px;
  background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.05);
  flex-wrap:wrap;
}
.stat .label{color:var(--muted); font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:.4px}
.stat .value{font-size:20px; font-weight:800}

.grid{display:grid; gap:16px}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}

/* Tables (default) */
.table-wrap{overflow:auto; border-radius:12px; border:1px solid rgba(255,255,255,.06)}
table{width:100%; border-collapse:separate; border-spacing:0; min-width:720px; background:rgba(255,255,255,.02)}
thead th{text-align:left; font-size:12px; color:#9aa0a6; font-weight:700; text-transform:uppercase; letter-spacing:.4px; padding:12px 14px; background:rgba(255,255,255,.03)}
tbody td{padding:14px; border-top:1px solid rgba(255,255,255,.06)}
tbody tr:hover{background:rgba(255,255,255,.03)}

/* HOME: Pool Coins → card rows */
#pool-coins{border-collapse:separate; border-spacing:0 10px; background:transparent}
#pool-coins thead th{background:transparent}
#pool-coins tbody td{border-top:none}
#pool-coins tbody tr{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.06);
}
#pool-coins tbody tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
#pool-coins tbody tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
#pool-coins tbody tr:hover{border-color:rgba(229,9,20,.35); box-shadow:0 8px 24px rgba(229,9,20,.10)}
#pool-coins td.coin span{display:flex; align-items:center; gap:10px; font-weight:800}
.pill{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
  font-weight:700; font-size:12px; color:#dfe1e8
}
td.algo{white-space:nowrap}
td.algo .pill{background:linear-gradient(135deg, rgba(229,9,20,.18), rgba(229,9,20,.08))}
td.fee .pill{background:rgba(255,255,255,.06)}
#pool-coins td.col-hide{text-align:right; font-weight:800; opacity:.9}

/* Sections/clean tables */
.section{margin:8px 0 0}
.section-title{margin:0 0 8px; font-size:16px; font-weight:800; letter-spacing:.2px}
.table-clean{overflow:auto}
.table-clean table{min-width:640px; background:transparent; border-spacing:0; border-collapse:separate}
.table-clean thead th{background:transparent; color:#a8abb4; border-bottom:1px solid rgba(255,255,255,.08)}
.table-clean tbody td{border-top:1px dashed rgba(255,255,255,.08)}
.table-clean tbody tr:hover{background:rgba(255,255,255,.02)}
.muted{color:#a3a3ad}

/* Workers redesign */
.card-workers .card-header{gap:12px}
.tools{display:flex; gap:8px; align-items:center}
.input-compact{
  padding:10px 12px; border-radius:10px; border:1px solid rgba(255,255,255,.12);
  background:#101017; color:#fff; min-width:160px; outline:none;
}
.input-compact:focus{box-shadow:var(--ring); border-color:rgba(229,9,20,.35)}
.table-wrap-dense table{min-width:0}
.table-workers thead th{position:sticky; top:0; background:rgba(21,21,28,.9); backdrop-filter:blur(6px)}
.table-workers tbody tr:nth-child(odd){background:rgba(255,255,255,.015)}
.table-workers tbody tr:hover{background:rgba(255,255,255,.03)}
#miner-workers{table-layout:fixed; width:100%}
#miner-workers th,#miner-workers td{overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
@media (max-width:640px){
  #miner-workers th:nth-child(4), #miner-workers td:nth-child(4){display:none}
}

/* Dashboard form – full row with actions on the right */
.page-dashboard .form-row{
  display:flex; width:100%; align-items:center; gap:12px; flex-wrap:nowrap;
}
.page-dashboard .input{
  flex:1; min-width:240px; padding:14px 16px 14px 44px;
  border-radius:12px; border:1px solid rgba(255,255,255,.12) !important;
  background:#101017 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="2" y="5" width="20" height="14" rx="2"/><path d="M16 12h.01"/></svg>') no-repeat 14px center / 18px 18px !important;
  color:#fff; outline:none;
}
.page-dashboard .input:focus{ box-shadow:var(--ring); border-color:rgba(229,9,20,.35) }
.page-dashboard .save-label{ margin-left:auto; display:flex;align-items:center;gap:8px;font-weight:700;color:#cfcfd6; white-space:nowrap }
.page-dashboard #rememberWallet{ width:18px;height:18px; accent-color:var(--brand) }
.page-dashboard .btn{ white-space:nowrap }
@media (max-width:980px){
  .page-dashboard .form-row{ flex-wrap:wrap }
  .page-dashboard .save-label{ order:2; margin-left:0 }
}

/* Payments table */
.table-payments table{ min-width:760px; background:rgba(255,255,255,.02) }
.hashchip{
  display:inline-block; max-width:260px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  border:1px solid rgba(255,255,255,.12); border-radius:10px; padding:6px 8px; font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
  background:rgba(255,255,255,.04);
}
@media (max-width:680px){
  .hashchip{max-width:100%}
}
.copy-mini{ margin-left:8px; border:none; border-radius:8px; padding:6px 8px; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; font-weight:800; cursor:pointer }

/* Code & pre → wrap (pas de débordement) */
pre{white-space:pre-wrap; word-break:break-word}
.kv-val code, .kv-key code{white-space:pre-wrap; word-break:break-word}

/* Icons */
.coinimg{width:16px; height:16px; margin-right:4px; vertical-align:middle}

/* Chartist */
.ct-chart{height:280px}
.ct-series-a .ct-line,.ct-series-a .ct-point{stroke:#ff474f}
.ct-series-b .ct-line,.ct-series-b .ct-point{stroke:#cfcfcf}
.ct-area{fill:rgba(229,9,20,.14)}
.ct-grid{stroke:rgba(255,255,255,.08)}
.ct-label{color:#9aa0a6; fill:#9aa0a6}

/* Blocks: progress */
.prog{position:relative; height:10px; background:rgba(255,255,255,.08); border-radius:999px; overflow:hidden}
.prog-bar{display:block; height:100%; width:var(--w,0%); background:linear-gradient(135deg,var(--brand),var(--brand-2));}
.prog-val{display:inline-block; margin-left:8px; font-weight:700; font-size:12px; color:#cfd1d9}

/* Effort color */
td.effort1{color:#18c77c} td.effort2{color:#a3a3ad} td.effort3{color:#f5a623} td.effort4{color:#ff4d4f}

/* Footer */
footer.footer{border-top:1px solid rgba(255,255,255,.06); padding:24px 0; color:#a3a3ad; margin-top:auto; background:transparent}

/* Brand colors in footer (Pool rouge, flix blanc) */
.footer .pool{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.footer .flix{ color:#fff; }

.content-wrapper .container, .main-index .container{padding-top:12px}

/* Responsive tweaks */
@media (max-width:960px){
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}
  .hero{flex-direction:column; align-items:flex-start}
  .menu a{padding:8px 10px}
  table{min-width:640px}
}

/* Connect lists */
.kv-list{display:flex; flex-direction:column; gap:10px}
.kv-item{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:12px 14px; border-radius:12px;
  background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.06)
}
.kv-key{font-weight:700; color:#c9c9d1; display:flex; align-items:center; gap:10px}
.kv-val{display:flex; align-items:center; gap:8px; min-width:40%; justify-content:flex-end; text-align:right}
@media (max-width:680px){
  .kv-item{flex-direction:column; align-items:flex-start}
  .kv-val{justify-content:flex-start; text-align:left; min-width:0; width:100%; flex-wrap:wrap}
}
.kv-val code, .kv-key code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  background:rgba(255,255,255,.05); padding:4px 6px; border-radius:8px; border:1px solid rgba(255,255,255,.08);
  font-weight:700; font-size:12px
}
.kv-copy{cursor:pointer; border:none; border-radius:8px; padding:6px 8px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; font-weight:800}
.subhead{margin:16px 0 8px; font-size:13px; color:#a8abb4; text-transform:uppercase; letter-spacing:.3px}

/* Fancy FAQ */
.faq-list{ display:flex; flex-direction:column; gap:10px }
details.faq{
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  border-radius:14px; padding:0 14px; transition:border-color .2s, box-shadow .2s;
}
details.faq[open]{ border-color:rgba(229,9,20,.35); box-shadow:var(--ring) }
details.faq summary{
  list-style:none; cursor:pointer; padding:14px 0; margin:0;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  font-weight:800; color:#e9e9ee;
}
details.faq summary::-webkit-details-marker{ display:none }
details.faq summary::after{
  content:"▸"; font-size:14px; transform:rotate(0deg); transition:transform .2s ease; opacity:.8;
}
details.faq[open] summary::after{ transform:rotate(90deg) }
details.faq p{ margin:0 0 14px; color:#c9c9d1; line-height:1.6 }

.coin-list-header,.main-sidebar{display:none !important}

/* --- Overrides Chartist dark --- */
.ct-chart .ct-label{ fill:#e6e6ea !important; color:#e6e6ea !important; }
.ct-chart .ct-grid{ stroke:rgba(255,255,255,.12) !important; }

/* ======= Mobile tables without horizontal scroll ======= */
@media (max-width:680px){
  .container{width:min(1280px,94vw)}
  .table-wrap{overflow:visible}
  table.stack{min-width:0; width:100%; background:transparent; border-spacing:0}
  table.stack thead{display:none}
  table.stack, table.stack tbody, table.stack tr, table.stack td{display:block; width:100%}
  table.stack tr{
    margin:0 0 10px; padding:8px;
    border:1px solid rgba(255,255,255,.08);
    border-radius:12px;
    background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  }
  table.stack td{
    display:flex; align-items:center; justify-content:space-between;
    gap:12px; padding:10px 8px; border:none; border-bottom:1px solid rgba(255,255,255,.06);
  }
  table.stack td:last-child{border-bottom:none}
  table.stack td::before{
    content:attr(data-label);
    flex:1; min-width:120px; max-width:55%;
    font-size:12px; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.4px
  }
  table.stack td > *{max-width:45%; text-align:right}
}

/* ===== Payments header (mobile): title on top + one-line toolbar + SVG icon ===== */
@media (max-width:680px){
  /* Titre sur sa propre ligne */
  .page-payments .card-header{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .page-payments .card-header .card-title{
    width:100%;
    margin:0;
  }

  /* Toolbar d'une seule ligne : « | date | Today | » | ⟳ */
  .page-payments .card-header .tools{
    display:grid;
    grid-template-columns:38px minmax(120px,1fr) auto 38px 38px;
    align-items:center;
    gap:6px;
    width:100%;
  }

  /* Contrôles compacts et rétrécissables */
  .page-payments .card-header .tools .btn,
  .page-payments .card-header .tools .input-compact{ min-width:0 }
  .page-payments .card-header .tools .btn{
    padding:8px 10px; font-size:12px; line-height:1;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  #btnPaymentsPrev,#btnPaymentsNext,#btnRefreshPayments{
    width:38px; padding:8px 0; display:grid; place-items:center;
  }

  /* Refresh : icône SVG par pseudo-élément (pas de changement HTML) */
  #btnRefreshPayments{ position:relative; border-radius:10px; font-size:0; line-height:0; }
  #btnRefreshPayments::before{
    content:""; display:block; width:18px; height:18px;
    background: center / 18px 18px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='23 4 23 10 17 10'/%3E%3Cpath d='M20.5 15a9 9 0 1 1 2.1-9'/%3E%3C/svg%3E");
  }
  #btnRefreshPayments:active::before{ transform:scale(.96) }

  /* Rows Payments : wrap d'adresses propre, pas d'overflow */
  #payments td:nth-child(2) code{
    display:inline-block; max-width:100%;
    white-space:normal; overflow-wrap:anywhere; word-break:break-all;
  }
  #payments.stack td::before{ max-width:40% }
  #payments.stack td > *{ max-width:60% }
  #payments .hashchip{ max-width:100% }
}

/* ===== Confirmations (prog + %) sur une seule ligne — robuste ===== */
/* Fallback universel : barre inline, largeur contrôlée */
td .prog{
  display:inline-block;
  width:clamp(110px, 40%, 160px);
  max-width:100%;
  vertical-align:middle;
}
td .prog-val{
  display:inline-block;
  margin-left:8px;
  white-space:nowrap;
  vertical-align:middle;
}

/* Amélioration si :has() dispo : on gère la cellule en flex */
@supports selector(:has(*)){
  td:has(.prog){
    display:flex;
    align-items:center;
    gap:8px;
  }
  td:has(.prog) .prog{
    flex:0 0 140px;
    max-width:140px;
  }
  td:has(.prog) .prog-val{
    flex:0 0 auto;
    white-space:nowrap;
  }

  /* Mode table empilée (mobile) : collés l’un à l’autre, pas de reflow */
  @media (max-width:680px){
    table.stack td:has(.prog){
      justify-content:flex-start;  /* annule space-between global */
      flex-wrap:nowrap;
      gap:8px;
    }
    table.stack td:has(.prog) .prog{
      flex:0 0 clamp(110px, 50%, 160px);
      max-width:none;
    }
  }
}
