/* Tracking Armevo — moteur de thèmes (widget + 9 layouts + thèmes signature).
   Partagé par l'écran de réglages (aperçu) et l'affichage boutique. */
  /* ───────── Widget de base (thémé par variables) ───────── */
  .tw{font-family:var(--font);color:var(--text);line-height:1.5;--gap:14px;--on-accent:#fff;--tac-failed:#ef4444;--tac-relay:#f59e0b;--tac-delayed:#f472b6;container-type:inline-size;max-width:var(--tw-max,480px);margin-left:auto;margin-right:auto}
  .tw *{box-sizing:border-box}
  .tw a{text-decoration:none}
  .tw>*+*{margin-top:var(--gap)}
  /* Bloc boutique */
  .tw-shop{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:11px 14px}
  .tw-logo{width:42px;height:42px;border-radius:calc(var(--radius)*.6);background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;font-family:var(--font)}
  .tw-shop-txt{display:flex;flex-direction:column;flex:1;min-width:0}
  .tw-shop-name{font-weight:700;font-size:14px}
  .tw-shop-slogan{font-size:11.5px;color:var(--muted)}
  .tw-shop-ic{display:flex;gap:6px;flex-shrink:0}
  .tw-shop-ic a{width:28px;height:28px;border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--muted)}
  .tw-shop-ic svg{width:13px;height:13px}
  /* Carte statut */
  .tw-status{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
  .tw-status-top{display:flex;align-items:center;gap:10px;padding:11px 15px;background:color-mix(in srgb,var(--accent) 9%,var(--surface));border-bottom:1px solid color-mix(in srgb,var(--accent) 16%,var(--line))}
  .tw-truck{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);flex-shrink:0}
  .tw-truck svg{width:16px;height:16px}
  .tw-status-lbl{font-weight:700;font-size:16px;color:var(--accent)}
  .tw-rows{padding:2px 15px}
  .tw-row{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
  .tw-row:last-child{border-bottom:none}
  .tw-row .k{color:var(--muted)}
  .tw-row .v{font-weight:600}
  .tw-row .mono{font-family:'Spline Sans Mono',monospace;font-weight:500}
  /* Estimation */
  .tw-est{font-size:13px;padding:10px 14px;border:1px dashed color-mix(in srgb,var(--accent) 35%,var(--line));border-radius:var(--radius);color:var(--text)}
  .tw-est b{color:var(--accent)}
  /* Upsell */
  .tw-up{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;border:2px solid var(--accent);border-radius:var(--radius);padding:12px 14px}
  .tw-up-img{width:52px;height:52px;border-radius:calc(var(--radius)*.6);background:color-mix(in srgb,var(--accent) 14%,var(--surface));display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
  .tw-up-txt{flex:1;min-width:0;display:flex;flex-direction:column}
  .tw-up-title{font-weight:700;font-size:13px}
  .tw-up-desc{font-size:11.5px;color:var(--muted)}
  .tw-up-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
  .tw-up-price{font-weight:700;color:var(--accent);font-size:15px;white-space:nowrap}
  .tw-up-btn{background:var(--accent);color:var(--on-accent);border-radius:calc(var(--radius)*.55);padding:9px 16px;font-size:12px;font-weight:700;letter-spacing:.02em;white-space:nowrap}
  @container (max-width:440px){.tw-up{flex-wrap:wrap}.tw-up-cta{flex-basis:100%;margin-top:4px}.tw-up-btn{flex:1;text-align:center}}

  /* ───────── Layout : Stepper (vertical) ───────── */
  .s-stepper{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px}
  .s-node{display:grid;grid-template-columns:40px 1fr;gap:13px;align-items:start;position:relative;padding-bottom:16px}
  .s-node:last-child{padding-bottom:0}
  .s-node::before{content:"";position:absolute;left:19px;top:42px;bottom:-2px;width:2px;background:var(--line)}
  .s-node:last-child::before{display:none}
  .s-node.r::before{background:var(--accent)}
  .s-node .dot{width:40px;height:40px;border-radius:50%;background:var(--surface);border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:17px;filter:grayscale(1) opacity(.4)}
  .s-node.r .dot{border-color:var(--accent);background:var(--accent);filter:none}
  .s-node.c .dot{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent)}
  .s-node-txt{display:flex;flex-direction:column;padding-top:9px}
  .s-node .lbl{font-size:13.5px;color:var(--muted);font-weight:600;line-height:1.3}
  .s-node.r .lbl{color:var(--text)}
  .s-node .t{font-size:11px;color:var(--muted);margin-top:2px}

  /* ───────── Layout : Timeline ───────── */
  .s-timeline{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
  .t-row{display:grid;grid-template-columns:20px 1fr;gap:11px;position:relative;padding-bottom:15px}
  .t-row:last-child{padding-bottom:0}
  .t-row::before{content:"";position:absolute;left:9px;top:15px;bottom:-2px;width:2px;background:var(--line)}
  .t-row:last-child::before{display:none}
  .t-row.r::before{background:var(--accent)}
  .t-dot{width:11px;height:11px;border-radius:50%;background:var(--surface);border:2px solid var(--line);margin-top:4px}
  .t-row.r .t-dot{background:var(--accent);border-color:var(--accent)}
  .t-row.c .t-dot{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent)}
  .t-lbl{font-weight:600;font-size:13.5px;color:var(--muted)}
  .t-row.r .t-lbl{color:var(--text)}
  .t-emoji{margin-right:5px;filter:grayscale(1) opacity(.4)}
  .t-row.r .t-emoji{filter:none}
  .t-msg{font-size:12px;color:var(--muted);margin-top:1px}
  .t-time{font-size:11px;color:var(--muted);margin-top:2px}

  /* ───────── Layout : Compact ───────── */
  .s-compact{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}
  .c-track{height:8px;border-radius:5px;background:var(--line);overflow:hidden}
  .c-fill{display:block;height:100%;border-radius:5px;background:var(--accent)}
  .c-row{display:flex;justify-content:space-between;font-size:12.5px;margin-top:9px;color:var(--muted)}
  .c-row b{color:var(--text)}
  .c-det{margin-top:11px}
  .c-det summary{cursor:pointer;font-size:12.5px;color:var(--accent);font-weight:700;list-style:none}
  .c-det summary::-webkit-details-marker{display:none}
  .c-det .s-timeline{border:none;padding:12px 0 0}

  /* ───────── Layout : Bar (minimal) ───────── */
  .s-bar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 17px}
  .b-top{display:flex;align-items:center;gap:9px;margin-bottom:11px}
  .b-emoji{font-size:20px}
  .b-label{font-weight:700;font-size:15px}
  .b-track{height:6px;border-radius:4px;background:var(--line);overflow:hidden}
  .b-fill{display:block;height:100%;border-radius:4px;background:var(--accent)}
  .b-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-top:9px}

  /* ───────── Layout : Simple (épuré) ───────── */
  .s-simple{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:6px 16px}
  .si-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}
  .si-row:last-child{border-bottom:none}
  .si-e{font-size:18px;width:24px;text-align:center;filter:grayscale(1) opacity(.4)}
  .si-row.r .si-e{filter:none}
  .si-lbl{flex:1;font-size:14px;color:var(--muted)}
  .si-row.r .si-lbl{color:var(--text);font-weight:600}
  .si-row.c .si-lbl{color:var(--accent)}
  .si-time{font-size:11px;color:var(--muted)}
  .si-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--on-accent);font-weight:700}
  .si-row.r .si-check{background:var(--accent);border-color:var(--accent)}
  .si-row.c .si-check{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}

  /* ───────── Layout : Cartes ───────── */
  .s-cards{display:flex;flex-direction:column;gap:8px}
  .ca-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:calc(var(--radius)*.7);border:1px solid var(--line);background:var(--surface)}
  .ca-row.r{border-color:color-mix(in srgb,var(--accent) 35%,var(--line));background:color-mix(in srgb,var(--accent) 6%,var(--surface))}
  .ca-row.c{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%,transparent)}
  .ca-badge{width:38px;height:38px;border-radius:calc(var(--radius)*.55);display:flex;align-items:center;justify-content:center;font-size:19px;background:color-mix(in srgb,var(--accent) 9%,var(--surface));flex-shrink:0;filter:grayscale(1) opacity(.42)}
  .ca-row.r .ca-badge{filter:none;background:color-mix(in srgb,var(--accent) 16%,var(--surface))}
  .ca-txt{flex:1;min-width:0}
  .ca-lbl{font-weight:600;font-size:13.5px}
  .ca-row:not(.r) .ca-lbl{color:var(--muted)}
  .ca-msg{font-size:11.5px;color:var(--muted);margin-top:1px}
  .ca-time{font-size:11px;color:var(--muted);flex-shrink:0}

  /* ───────── Layout : Hero ───────── */
  .s-hero{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 20px;text-align:center}
  .h-emoji{font-size:40px;line-height:1}
  .h-label{font-weight:700;font-size:20px;margin-top:10px;color:var(--accent);font-family:var(--font)}
  .h-msg{font-size:13px;color:var(--muted);margin-top:4px}
  .h-ticks{display:flex;gap:6px;justify-content:center;margin-top:16px}
  .h-tick{width:26px;height:5px;border-radius:3px;background:var(--line)}
  .h-tick.r{background:var(--accent)}
  .h-tick.c{background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}

  /* ───────── Layout : Numéroté ───────── */
  .s-num{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:4px 16px}
  .nu-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px dashed var(--line)}
  .nu-row:last-child{border-bottom:none}
  .nu-idx{font-family:var(--font);font-weight:700;font-size:23px;width:36px;text-align:center;color:var(--line);flex-shrink:0;line-height:1}
  .nu-row.r .nu-idx{color:var(--accent)}
  .nu-body{flex:1;min-width:0}
  .nu-lbl{font-weight:600;font-size:14px}
  .nu-row:not(.r) .nu-lbl{color:var(--muted)}
  .nu-msg{font-size:11.5px;color:var(--muted);margin-top:1px}
  .nu-time{font-size:11px;color:var(--muted);flex-shrink:0}

  /* ───────── Layout : Rail (épine de progression) ───────── */
  .s-rail{display:flex;gap:15px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}
  .rail-spine{width:6px;border-radius:6px;background:var(--line);position:relative;flex-shrink:0}
  .rail-spine::after{content:"";position:absolute;left:0;top:0;width:100%;border-radius:6px;background:var(--accent);height:var(--p,0%)}
  .rail-list{flex:1;display:flex;flex-direction:column;min-width:0}
  .rail-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
  .rail-item:last-child{border-bottom:none}
  .rail-e{font-size:16px;width:22px;text-align:center;filter:grayscale(1) opacity(.4)}
  .rail-item.r .rail-e{filter:none}
  .rail-lbl{flex:1;font-size:13.5px;color:var(--muted)}
  .rail-item.r .rail-lbl{color:var(--text);font-weight:600}
  .rail-item.c .rail-lbl{color:var(--accent)}
  .rail-time{font-size:11px;color:var(--muted)}

  /* ═══════════ Onglet ZINZIN : thèmes signature ═══════════ */
  /* Glassmorphism */
  .z-glass .tw-shop,.z-glass .tw-status,.z-glass .tw-est,.z-glass .s-simple,.z-glass .s-num,.z-glass .s-rail,.z-glass .s-bar,.z-glass .s-hero,.z-glass .ca-row,.z-glass .tw-up{background:rgba(255,255,255,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.7);box-shadow:0 8px 32px rgba(80,40,160,.16)}
  /* Neobrutalism */
  .z-brut .tw-shop,.z-brut .tw-status,.z-brut .tw-est,.z-brut .s-simple,.z-brut .s-num,.z-brut .s-rail,.z-brut .s-bar,.z-brut .s-hero,.z-brut .ca-row,.z-brut .tw-up{border:2.5px solid #111!important;box-shadow:4px 4px 0 #111;border-radius:3px!important}
  .z-brut .tw-up-btn{border:2.5px solid #111;box-shadow:3px 3px 0 #111;border-radius:3px}
  .z-brut .tw-logo{border:2.5px solid #111;box-shadow:2px 2px 0 #111}
  /* Aurora mesh */
  .z-aurora .tw-shop,.z-aurora .tw-status,.z-aurora .tw-est,.z-aurora .s-simple,.z-aurora .s-num,.z-aurora .s-rail,.z-aurora .s-bar,.z-aurora .s-hero,.z-aurora .ca-row,.z-aurora .tw-up{background:rgba(255,255,255,.85);backdrop-filter:blur(6px);box-shadow:0 6px 24px rgba(99,102,241,.10)}
  /* Néon glow */
  .z-neon .tw-up-btn{box-shadow:0 0 16px var(--accent),0 0 4px var(--accent)}
  .z-neon .tw-status-lbl,.z-neon .h-label{text-shadow:0 0 12px color-mix(in srgb,var(--accent) 70%,transparent)}
  .z-neon .nu-row.r .nu-idx{text-shadow:0 0 10px color-mix(in srgb,var(--accent) 60%,transparent)}
  .z-neon .rail-spine::after,.z-neon .b-fill,.z-neon .c-fill{box-shadow:0 0 10px var(--accent)}
  .z-neon .ca-row.c,.z-neon .si-row.r .si-check{box-shadow:0 0 14px color-mix(in srgb,var(--accent) 55%,transparent)}
  /* Gradient pop */
  .z-grad .tw-up-btn,.z-grad .tw-logo{background:linear-gradient(135deg,#f472b6,#a855f7,#6366f1)}
  .z-grad .b-fill,.z-grad .c-fill,.z-grad .rail-spine::after{background:linear-gradient(90deg,#f472b6,#a855f7,#6366f1)}
  .z-grad .tw-status-top{background:linear-gradient(135deg,rgba(244,114,182,.12),rgba(99,102,241,.12))}
  .z-grad .h-label,.z-grad .tw-status-lbl{background:linear-gradient(135deg,#ec4899,#6366f1);-webkit-background-clip:text;background-clip:text;color:transparent}
  /* Claymorphism */
  .z-clay .tw-shop,.z-clay .tw-status,.z-clay .tw-est,.z-clay .s-simple,.z-clay .s-num,.z-clay .s-rail,.z-clay .s-bar,.z-clay .s-hero,.z-clay .ca-row,.z-clay .tw-up{border:none!important;box-shadow:-5px -5px 12px rgba(255,255,255,.9),6px 6px 14px rgba(120,100,180,.22)}
  .z-clay .tw-up-btn,.z-clay .tw-logo{box-shadow:-3px -3px 7px rgba(255,255,255,.55),4px 4px 9px rgba(80,50,140,.3)}
  /* Vaporwave */
  .z-vapor .tw-shop,.z-vapor .tw-status,.z-vapor .tw-est,.z-vapor .s-simple,.z-vapor .s-num,.z-vapor .s-rail,.z-vapor .s-bar,.z-vapor .s-hero,.z-vapor .ca-row,.z-vapor .tw-up{background:rgba(255,255,255,.82);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7)}
  .z-vapor .tw-up-btn,.z-vapor .tw-logo{background:linear-gradient(120deg,#05d9e8,#ff2d95)}
  .z-vapor .h-label{background:linear-gradient(120deg,#05d9e8,#ff2d95);-webkit-background-clip:text;background-clip:text;color:transparent}
  /* Onyx & or */
  .z-onyx .tw-up-btn,.z-onyx .tw-logo{background:linear-gradient(135deg,#e7cd8f,#b8893f);color:#1a160c}
  .z-onyx .tw-shop,.z-onyx .tw-status,.z-onyx .tw-est,.z-onyx .s-simple,.z-onyx .s-num,.z-onyx .s-rail,.z-onyx .s-bar,.z-onyx .s-hero,.z-onyx .ca-row,.z-onyx .tw-up{box-shadow:0 4px 20px rgba(0,0,0,.4)}
  .z-onyx .h-label,.z-onyx .tw-status-lbl{background:linear-gradient(135deg,#e7cd8f,#b8893f);-webkit-background-clip:text;background-clip:text;color:transparent}
  /* Bento SaaS */
  .z-bento .tw-shop,.z-bento .tw-status,.z-bento .tw-est,.z-bento .s-simple,.z-bento .s-num,.z-bento .s-rail,.z-bento .s-bar,.z-bento .s-hero,.z-bento .ca-row,.z-bento .tw-up{box-shadow:0 1px 2px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.05)}
  /* Holographique */
  .z-holo .tw-shop,.z-holo .tw-status,.z-holo .tw-est,.z-holo .s-simple,.z-holo .s-num,.z-holo .s-rail,.z-holo .s-bar,.z-holo .s-hero,.z-holo .ca-row,.z-holo .tw-up{background:rgba(255,255,255,.72);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.85);box-shadow:0 6px 26px rgba(168,85,247,.13)}
  .z-holo .tw-up-btn,.z-holo .tw-logo{background:linear-gradient(120deg,#f0abfc,#a5b4fc,#7dd3fc)}

  /* ═══════════ Onglet NICHES : thèmes métier ═══════════ */
  /* Cartoon */
  .z-cartoon .tw-shop,.z-cartoon .tw-status,.z-cartoon .tw-est,.z-cartoon .s-simple,.z-cartoon .s-num,.z-cartoon .s-rail,.z-cartoon .s-bar,.z-cartoon .s-hero,.z-cartoon .ca-row,.z-cartoon .tw-up{border:2.5px solid #2b2b2b!important;box-shadow:3px 3px 0 #2b2b2b}
  .z-cartoon .tw-up-btn,.z-cartoon .tw-logo{border:2.5px solid #2b2b2b;box-shadow:2px 2px 0 #2b2b2b}
  /* Manga (encrage + trame) */
  .z-manga .tw-shop,.z-manga .tw-status,.z-manga .tw-est,.z-manga .s-simple,.z-manga .s-num,.z-manga .s-rail,.z-manga .s-bar,.z-manga .s-hero,.z-manga .ca-row,.z-manga .tw-up{border:2px solid #111!important}
  .z-manga .tw-status-top{border-bottom:2px solid #111}
  .z-manga .tw-status-lbl,.z-manga .h-label{font-style:italic}
  /* Carbone (auto / moto) */
  .z-carbon .tw-shop,.z-carbon .tw-status,.z-carbon .tw-est,.z-carbon .s-simple,.z-carbon .s-num,.z-carbon .s-rail,.z-carbon .s-bar,.z-carbon .s-hero,.z-carbon .ca-row,.z-carbon .tw-up{border:1px solid #34383e;box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 4px 16px rgba(0,0,0,.4)}
  .z-carbon .tw-up-btn,.z-carbon .tw-logo{box-shadow:0 2px 10px color-mix(in srgb,var(--accent) 55%,transparent)}
  /* Joaillerie (or) */
  .z-jewel .tw-up-btn,.z-jewel .tw-logo{background:linear-gradient(135deg,#e3c987,#b08d3f);color:#3a2e12}
  .z-jewel .h-label,.z-jewel .tw-status-lbl{background:linear-gradient(135deg,#c9a24a,#8a6c2a);-webkit-background-clip:text;background-clip:text;color:transparent}
  .z-jewel .tw-shop,.z-jewel .tw-status,.z-jewel .tw-est,.z-jewel .s-simple,.z-jewel .s-num,.z-jewel .s-rail,.z-jewel .s-bar,.z-jewel .s-hero,.z-jewel .ca-row,.z-jewel .tw-up{box-shadow:0 4px 18px rgba(150,120,50,.12)}

  /* ═══════════ États d'incident (recolore le marqueur de l'étape) ═══════════ */
  .s-node.is-failed,.t-row.is-failed,.si-row.is-failed,.ca-row.is-failed,.nu-row.is-failed,.rail-item.is-failed,.s-hero.is-failed{--accent:var(--tac-failed)}
  .s-node.is-relay,.t-row.is-relay,.si-row.is-relay,.ca-row.is-relay,.nu-row.is-relay,.rail-item.is-relay,.s-hero.is-relay{--accent:var(--tac-relay)}
  .s-node.is-delayed,.t-row.is-delayed,.si-row.is-delayed,.ca-row.is-delayed,.nu-row.is-delayed,.rail-item.is-delayed,.s-hero.is-delayed{--accent:var(--tac-delayed)}
  /* l'étape en incident garde un libellé bien visible */
  .t-row.is-failed .t-lbl,.si-row.is-failed .si-lbl,.nu-row.is-failed .nu-lbl,.rail-item.is-failed .rail-lbl,.ca-row.is-failed .ca-lbl{color:var(--tac-failed);font-weight:700}

  /* ═══════════ Habillage côté boutique (plugin) ═══════════ */
  .tac-stage{padding:22px 18px;border-radius:16px;transition:background .2s}
  .tac-stage .tw{max-width:480px;margin:0 auto}
  .tw-logo.tac-logo-img{background:#fff;overflow:hidden;padding:3px}
  .tw-logo.tac-logo-img img{width:100%;height:100%;object-fit:contain;display:block}
  .tw-up-img{overflow:hidden}
  .tw-up-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
