    html, body {
      height: 100%;
      margin: 0;
      background: #000;
      color: #fff;
      font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    }
    .wrap {
      height: 100%;
      display: grid;
      <!-- grid-template-rows: 1fr auto; -->
    }
    #stage {
      position: relative;
      display: grid;
      place-items: center;
      overflow: hidden;
      background: url('../assets/atelier.png') center/cover no-repeat;
    }
    canvas { display:block; width:100%; height:100%; }
    .logo {
      position:absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width:min(38vmin, 45vh);
      height:min(38vmin, 45vh);
      object-fit: cover;
      border-radius: 50%;
      background: #000;
      filter: drop-shadow(0 0 8px rgba(0,0,0,.6));
      pointer-events:none;
      user-select:none;
    }
    .panel {
      position: fixed; 
      bottom: 0;      
      left: 0;         
      right: 0;       
      z-index: 10;    
      display:flex;
      flex-wrap:wrap;
      gap:.75rem;
      align-items:center;
      padding: .75rem 1rem;
      background: rgba(15,15,20,.9);
      border-top: 1px solid rgba(255,255,255,.08);
      transition: opacity 0.4s ease, transform 0.4s ease;
      opacity: 0;
      transform: translateY(100%);
      pointer-events: none;
  }
	.panel.visible {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }
    .panel > * { margin-right:.25rem; }
	.panel { pointer-events: auto; }
    .btn {
      background:#111;
      border:1px solid #2a2a2a;
      color:#fff;
      padding:.5rem .8rem;
      border-radius:.5rem;
      cursor:pointer;
    }
    .btn[disabled] { opacity:.5; cursor:not-allowed; }
    label {
      font-size:.9rem;
      opacity:.9;
    }
	.btn.active {
      background: #00ff88;
      color: #000;
      border-color: #00ff88;
    }
    input[type="range"] { width: 140px; }
    a.small { color:#9ad; text-decoration:none; font-size:.85rem; opacity:.9; }
	
	.progress-container {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-grow: 1; /* Prend l'espace restant */
      min-width: 200px;
    }
    .progress-container input[type="range"] {
      width: 100%;
    }
    .progress-container span {
      font-size: 0.85rem;
      min-width: 35px; /* Empêche le saut de layout */
      text-align: center;
    }
    #volume-label {
      min-width: 150px;
    }