/* ============================================================
   M1 - BALANÇO CONTROLADO (Kids 2)
   Adaptado de gangorra_middle.css
   Posições em % → ajuste top/left/width/height conforme o tapete kids2.jpeg
   ============================================================ */

/* Wrapper da missão (fica em cima do tapete) */
.m1k2-gangorra-wrap {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* ── Área branca alvo ──────────────────────────────────────────
   ⚠️  AJUSTE ESTAS % para bater com a área alvo no tapete kids2
   ──────────────────────────────────────────────────────────── */
#m1k2-alvo-branco {
  position: absolute;
  top: 87.5%;      /* ← AJUSTE */
  left: 61%;     /* ← AJUSTE */
  width: 19.4%;   /* ← AJUSTE */
  height: 3.5%;  /* ← AJUSTE */

  background: rgba(255, 255, 255, 0.70);
  border: 0.22vw solid rgba(255, 255, 255, 0.95);
  box-sizing: border-box;
  box-shadow: 0 0 0.9vw rgba(255, 255, 255, 0.35);

  pointer-events: none;
}

#m1k2-alvo-branco.m1k2-alvo-ok {
  background: rgba(0, 255, 0, 0.35);
  border-color: rgba(0, 255, 0, 0.95);
  box-shadow: 0 0 1.2vw rgba(0, 255, 0, 0.40);
}

/* ── Conjunto da gangorra ──────────────────────────────────────
   ⚠️  AJUSTE top/left/width/height para posicionar no tapete kids2
   ──────────────────────────────────────────────────────────── */
#m1k2-gangorra {
  position: absolute;
  top: 85%;       /* ← AJUSTE */
  left: 70.5%;      /* ← AJUSTE */
  width: 25.0%;   /* ← AJUSTE */
  height: 6.0%;   /* ← AJUSTE */
  transform: translate(-50%, -50%) scale(0.74);
  pointer-events: none;
}

/* Pivô */
.m1k2-pivo {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 1.2vw;
  height: 1.2vw;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: rgba(20, 20, 20, 0.85);
  outline: 0.25vw solid rgba(255, 255, 255, 0.25);
}

/* Viga */
#m1k2-viga {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 0.9vw;
  transform-origin: 50% 50%;
  transform: translate(-50%, -50%) rotate(0deg);
  border-radius: 0.6vw;
  background: rgba(15, 90, 40, 0.9);
}

/* Pontas */
.m1k2-ponta {
  position: absolute;
  top: 50%;
  width: 1.8vw;
  height: 1.8vw;
  transform: translateY(-50%);
  border-radius: 0.4vw;
  background: rgba(10, 10, 10, 0.75);
  outline: 0.25vw solid rgba(255, 255, 255, 0.25);
}
.m1k2-ponta-esq { left: -0.6vw; }
.m1k2-ponta-dir { right: -0.6vw; }

/* ── Controle (slider vertical drag) ──────────────────────────
   ⚠️  AJUSTE top/left para posicionar o slider no tapete kids2
   ──────────────────────────────────────────────────────────── */
#m1k2-controle {
  position: absolute;
  top: 82%;   /* ← AJUSTE */
  left: 56%;  /* ← AJUSTE */
  width: 4.2vw;
  height: 12vw;
  transform: translate(-50%, -50%) scale(0.5);
  border-radius: 1.1vw;
  background: rgba(0, 0, 0, 0.72);
  outline: 0.28vw solid rgba(255, 255, 255, 0.45);
  box-shadow:
    0 0.8vw 1.4vw rgba(0, 0, 0, 0.35),
    0 0 0.9vw rgba(255, 255, 255, 0.10);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-direction: column;
  gap: 0.6vw;
  pointer-events: auto;
  user-select: none;
  touch-action: none;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

#m1k2-controle:hover {
  transform: translate(-50%, -50%) scale(0.7);
  box-shadow:
    0 1.0vw 1.6vw rgba(0, 0, 0, 0.40),
    0 0 1.1vw rgba(255, 255, 255, 0.16);
}

#m1k2-knob {
  width: 3.0vw;
  height: 3.0vw;
  border-radius: 1.0vw;
  background: rgba(255, 255, 255, 0.95);
  outline: 0.22vw solid rgba(0, 0, 0, 0.25);
  box-shadow:
    0 0.6vw 1.0vw rgba(0, 0, 0, 0.25),
    0 0 0.8vw rgba(255, 255, 255, 0.20);
  margin-top: 0.8vw;
  cursor: grab;
}

#m1k2-controle:active #m1k2-knob {
  cursor: grabbing;
  transform: scale(0.98);
}

.m1k2-controle-label {
  position: absolute;
  top: -2.6vw;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.0vw;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.95);
  background: rgba(0, 0, 0, 0.75);
  padding: 0.3vw 0.8vw;
  border-radius: 1.2vw;
  outline: 0.18vw solid rgba(255, 255, 255, 0.25);
  text-shadow: 0 0.25vw 0.45vw rgba(0, 0, 0, 0.65);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
}
